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4 二 
有 卓 局 
Preface 
学 会 站 在 巨人 的 肩膀 上 ! 
Web 项 目 开 发 的 终极 目标 是 完成 满足 用 户 需 求 的 项 目 。 一 个 项 目 往 往 包含 复杂 的 功 
能 。 作 为 一 名 程序 员 ， 需 要 在 有 限 的 时 间 内 实现 它们 ， 这 对 于 一 名 新 手 显然 并 不 容易 。 为 


何 有 开发 经 验 的 程序 员 编 程 效 率 会 非常 高 ? 答案 就 是 他 们 做 过 类 似 的 程序 ， 通过 适当 修改 
以 前 的 代码 就 可 以 满足 现在 的 要 求 。 因此 , 如 何 快 速 积累 编程 经 验 就 成 了 新 手 的 当务之急 。 
显然 ， 单 单 依靠 项 目 来 积累 速度 是 非常 慢 的 。 

本 书 图 文 并 成 、 难 易 并 举 ， 汇 集 了 265 个 日 常 开发 中 经 常 使 用 的 实例 ， 内 容 涵 盖 PHP 
语言 Web 项 目 开发 的 方方面面 。 每 个 实例 分 成 实例 说 明 、 实 现 过 程 和 技术 要 点 3 部 分 进 
行 讲解 。 通 过 学 习 本 书 ， 不 但 能 快速 掌握 相关 知识 点 ， 还 能 逐步 提高 编程 能 


本 书 内 容 


本 书 以 基础 知识 结构 为 框架 , 每 一 部 分 知识 都 有 范例 举证 , 不 但 是 对 基础 知识 的 巩固 ， 
更 能 够 体现 基础 知识 在 实战 开发 中 的 应 用 。 全 书 分 为 16 章 ， 内 容 包 括 PHP 基础 、 函 数 、 
PHP 流程 控制 语句 、Web 技术 、MySQL 数据 库 、PHP 数据 库 编 程 、 字 符 串 高 级 处 理 、PHP 
数组 应 用 、 日 期 和 时 间 的 处 理 、 图 形 图 像 处 理 、 文 件 目录 处 理 、 面 向 对 象 编程 、 PDO 数据 
库 抽象 层 、Smarty 模板 、ThinkPHP 框架 和 PHP 的 字符 编码 。 

为 了 更 清晰 地 阅 述 问题 和 给 出 问题 的 解决 方案 ， 本 书 设置 了 以 下 栏目 。 

实例 说 明 : 详细 描述 本 实例 的 用 途 ， 并 给 出 实例 的 运行 效果 图 。 

实现 过 程 逐步 讲解 如 何 解决 本 实例 的 问题 ， 并 给 出 关键 代码 、 注 意 事项 等 。 
加 ”技术 要 点 : 对 本 实例 使 用 的 关键 技术 进行 总 结 ， 方 便 日 后 使 用 。 


本 书 特色 


回 ”贴近 应 用 。 本 书 精 选 的 实例 都 是 真正 来 自 开 发 一 线 。 以 实例 的 形式 进行 讲解 ， 更 

回 ”横向 链接 。 本 书 知识 框架 与 《PHP 开发 入 门 及 项 目 实战 》 一 书 相对 应 ， 可 以 在 使 用 
《PHP 开发 入 门 及 项 目 实战 》 一 书 进 行 基础 学 习 之 后 ， 再 用 本 书 丰 富 并 提高 技能 。 

解析 透彻 。 本 书 对 每 个 问题 的 相关 知识 进行 细致 讲解 ， 并 进行 知识 拓展 ， 使 读者 
不 仅 知 其 然而 且 知 其 所 以 然 。 

授 人 以 渔 。 本 书 在 讲解 技术 的 同时 还 注重 对 读者 能 力 的 培养 ， 使 读者 掌握 分 析 问 
题 与 解决 问题 的 能 


多 


本 (要 友 组 由 编程 265 人 


本 书 配套 资源 


国内 “| 本 书 提 供 了 内 容 丰 富 的 配套 资源 ， 包 括 源 程序 、 素 材 ， 以 及 模块 库 、 案 例 库 、 古 库 、 
一 素材 库 等 多 项 辅助 内 容 ， 读 者 朋友 可 以 通过 如 下 方式 获取 。 
第 工种 方式 : 
| (1) 登录 wwwtup.com.cn， 在 网 页 右上 角 的 搜索 文本 框 中 输入 本 书 书 名 注意 区 分 
| 大 小 写 和 留 出 空格 )， 或 者 输入 本 书 关键 字 ， 或 者 输入 本 书 ISBN 号 (注意 去 掉 ISBN 号 间 
| 隔 线 “-”)， 单 击 “ 搜 索 ” 按 钮 。 
| (2) 找到 本 书后 单 击 超 链接 ， 在 该 书 的 网 页 下 侧 单 击 “ 网 络 资源 ” 超 链接 ， 即 可 下 载 。 


第 2 种 方式 : 
| 访问 本 书 的 新 浪 微 博 PHPbook， 找 到 配套 资源 的 链接 地 址 进行 下 载 。 
| 读者 人 群 


本 书 非常 适合 以 下 人 员 阅 读 : 

从 事 PHP 语言 编程 行业 的 开发 人 员 

有 一 定语 言 基 础 ， 想 进一步 提高 技能 的 人 员 
大 中 专 院 校 的 老师 和 学 生 

即将 走 上 工作 岗位 的 大 学 毕业 生 

相关 培训 机 构 的 老师 和 学 员 

PHP 语言 编程 爱好 者 


读者 服务 & 本 书 勘误 


读者 在 使 用 本 书 过 程 中 遇 到 的 所 有 问题 ， 均 可 通过 以 下 方式 联系 我 们 。 

1. 新 浪 微 博 : PHPbook。 

及 时 发 布 读者 答疑 、 本 书 勘误 、 配 套 资料 更 新 等 内 容 。 

2. 腾讯 QQ: 4006751066。 
| 3. 登录 网 站 : www.mingribook.com， 在 论坛 、 勘 误 发 布 、 读 者 纠 错 、 技 术 支持 、 读 
| 者 之 家 等 栏目 中 的 相关 模块 中 提问 、 留 言 或 查看 。 


本 书 作者 


| 


| 本 书 由 明日 科技 组 织 编写 ， 参 加 编写 的 有 潘 凯 华 、 李 慧 、 刘 欣 、 陈 丹 丹 、 王 国 辉 、 
| 张 振 坤 、 李 伟 、 沈 博 、 孙 秀 梅 、 曹 飞 飞 、 王 雪 、 朱 晓 、 赵 永 发 、 李 佬 、 高 春 攀 、 王 小 科 、 
| 赵 会 东 、 李 继 业 、 赛 奈 春 、 杨 丽 、 李 丽 、 刘 龄 龄 、 王 明 招 、 孙 昔 、 陈 英 、 肖 先 和 刘 冠 男 
| 等 。 由 于 作者 水 平 有 限 ， 玻 漏 和 不 足 之 处 在 所 难免 ， 僻 请 广大 读者 朋友 批评 指正 。 
| 编 者 
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PHP 基础 


本 章 读者 可 以 学 到 如 下 实例: 


豆 吾 于 于 对 于 对 于 于 至 


A 


实例 001 
实例 002 
实例 003 
实例 004 
实例 005 
实例 006 
实例 007 
实例 008 
实例 009 
实例 010 
实例 011 
实例 012 
实例 013 
实例 014 
实例 015 


获取 当前 执行 文件 的 名 称 
计算 一 个 圆 形 的 面积 

当 数 字 遇 到 字符 囊 

通过 转 义 字符 输出 特殊 字符 囊 
通过 PHP5 新 型 字符 串 动态 输出 JavaScript 代码 
比较 两 个 时 间 鹤 的 大 小 

判断 数字 的 奇偶 性 

通过 逻辑 运算 符 判 断 用 户 的 权限 
获取 2000~2020 年 中 所 有 的 头 年 
自 定义 数字 加 密 算 法 

随机 输出 字符 囊 

在 页 面 中 打印 服务 器 时 间 

区 分 单 引号 和 双 引 号 

前 置 运算 符 和 后 置 运算 符 的 区 别 
使 用 可 变 变 量 输出 “ILike PHP!” 


需 


| 免 有 些 麻烦 ， 这 时 可 以 使 用 _FILE “预定 义 函 数 。 本 
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&% 
实例 001 获取 当前 执行 文件 的 名 称 
( 实 便 位置 : 配套 资源 \SL\01\001 视频 位 置 : 配套 资源 \SP\01\001 ) 
实例 说 明 


很 多 时 候 用 户 需 要 编写 包含 文件 路 径 及 文件 名 称 的 代码 , 如果 通过 目录 去 查找 , 未 


| 实例 通过 _FILE_ 预 定义 常量 获取 目标 文件 的 路 径 DWppSerwiwwsl\oloolNindsx php 


| 及 文件 名 称 并 在 网 页 上 进行 打印 ， 运 行 结果 如 图 1.1 
| 所 示 。 


图 1.1 输出 当前 文件 路 径 和 名 称 


| 实现 过 程 


| 技术 要 点 


创建 mdex.php 文件 ， 并 通过 echo 语句 输出 _FILE_ 预 定义 常量 。 其 代码 如 下 : 
<?php 
echo FILE : // 获 取 文 件 的 完整 路 径 


2 


系统 预定 义 常量 和 用 户 自 定 义 常量 在 使 用 上 没有 差别 。 大 多 数 的 预定 义 常量 的 执行 结 


果 都 是 服务 器 的 相关 信息 (如 版 本 号 、 路 径 、 错 误 参 数 等 )， 所 以 程序 员 很 少将 此 函数 用 


于 网 站 前 台 的 开发 ， 如 果 被 别有用心 的 人 知道 了 这 些 信 息 ， 会 严重 威胁 到 服务 器 的 安全 。 


| 使 用 此 函数 的 语法 说 明 如 下 : 


_FILE 预定 义 常量 : 文件 的 完整 路 径 和 文件 名 。 如 果 用 在 包含 文件 中 ， 则 返回 包含 


| 文件 名 。 自 PHP 4.0.2 起，_FILE_ 总 是 包含 一 个 绝对 路 径 ， 而 在 此 之 前 的 版 本 有 时 会 包 


含 一 个 相对 路 径 。 


多 学 两 招 : 


PHP 中 可 以 使 用 预定 义 常量 获取 PHP 中 的 信息 。 常 用 的 预定 义 常量 如 表 1.1 所 示 。 


表 1.1 PHP 的 预定 义 常量 


常 量 名 功 能 
FILE 默认 常量 ，PHP 程序 文件 名 
LINE 默认 常量 ，PHP 程序 行 数 
PHP VERSION 内 建 常量 ，PHP 程序 的 版 本 ， 如 “3.0.8_dev” 
PHP OS 内 建 常量 ， 执 行 PHP 解析 器 的 操作 系统 名 称 ， 如 “Windows” 
TRUE 这 个 常量 是 一 个 真 值 (true) 
FALSE 这 个 常量 是 一 个 假 值 false) 
NULL -个 null 值 
E ERROR 这 个 常量 指 到 最 近 的 错误 处 
E WARNING 这 个 常量 指 到 最 近 的 警告 处 


De 


常 量 名 


功 能 
这 个 常量 指 解 析 语 法 有 潜在 问题 处 
这 个 常量 为 发 生 不 寻常 但 不 一 定 是 错误 处 


E NOTICE 


脚下 留神 : 
FILE 和 LINE 中 的 “ ”是 两 条 下 划 线 ,而 不 是 一 条 “”。 表 1.1 中 以 EE 开头 的 
预定 义 常量 是 PHP 的 错误 调试 部 分 。 如 果 读 者 想 详细 了 解 ， 可 参考 error reporting( 〇 函数 。 


实例 002 计算 一 个 圆 形 的 面积 


( 实例 位 置 : 配套 资源 \SL\01\002 视频 位 置 配套 资源 \SP\01\002 ) 


实例 说 明 

常量 是 PHP 编程 基础 的 重要 组 成 部 分 , 其 作用 是 定义 一 个 不 会 改变 的 值 。 本 实例 通过 
计算 圆 的 面积 向 用 户 说 明 常 8 量 是 如 何 定义 和 使 用 的 ， 运 行 结 果 如 图 1.2 所 示 。 

12 7 toniR452 3893344 | 
图 1.2 使 用 常量 指定 半径 的 值 并 计算 圆 的 面积 

大 现 过 程 

具体 步骤 如 下 : 

(1) 创建 PHP 脚本 文件 。 首 先 ， 通 过 defineO 函 数 定义 常量 ， 将 数值 “3.1415926” 
定义 常量 名 为 PI。 然 后 , 定义 数值 型 变量 , 将 圆 的 半径 设 定 为 12 个 单位 。 最 后 ， 通 过 echo 
语句 输出 圆 面 积 。 其 代码 如 下 : 


<2php 
define("PI",3.1415926): /定义 常量 
S$r= 12; // 定 义 圆 半径 
echo "半径 为 12 个 单位 的 圆 的 面积 ".PI*($r*$r); // 定 义 圆 面 积 
?> 


(2) 将 该 文件 存储 于 \MR\01\002\ 文 件 夹 下 ， 并 命名 为 indexphp。 运 行 结 果 如 图 1.2 
所 示 。 


技术 要 点 


PHP 中 通常 使 用 define0 函 数 来 定义 常量 ;使 用 constant0 函 数 动态 获取 常量 值 ， 使 用 
defined0) 函 数 判断 一 个 常量 是 否 已 经 定义 ; 使 用 get_defined_constants() 函 数 获取 所 有 当前 
已 经 定义 的 常量 。 本 实例 主要 使 用 define0 函 数 来 定义 常量 ， 该 函数 语法 如 下 : 

bool define ( string name, mixed value [, bool case_insensitive] ); 


。3。 
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A 
参数 说 明 : 
回 ”string name: 必 选 参数 ， 常 量 名 称 ， 即 标识 符 。 
| mixed value: 必 选 参数 ， 常 量 的 值 。 
天 六 | 回 ”bool case_insensitive: 可 选 参数 ， 指 定 大 小 写 敏感 ， 设 定 为 tue， 表 示 不 敏感 。 


| 助 下 留神 
用 define0) 定 义 的 常量 一 旦 定义 就 不 能 改变 或 取消 。 


实例 003” 当 数字 遇 到 字符 串 


( 实例 位 置 : 配套 资源 \SL\01\003 视频 位 置 : 配套 资源 \SP\01\003 ) 


”实例 说 明 

| 在 PHP 手册 中 经 常会 看 到 一 些 返回 值 为 Boolean 的 函数 ,函数 说 明 的 讲解 可 能 是 当 符 
| 合 条 件 时 ， 返 回 值 为 1， 否则 返回 值 为 0。 按照 我 们 正常 的 思维 返回 值 应 该 是 tue 和 false， 
| 因为 它们 才 是 真正 的 Boolean 类 型 ， 其 实 这 些 都 是 类 型 转换 的 应 用 。 本 实例 介绍 PHP 中 的 
| 数据 类 型 的 知识 ， 展 示 数据 是 如 何 进行 类 型 转换 的 ， 运 行 结果 如 图 13 所 示 。 


i 
2( 申 型 数据 =20 
EE 


.201 是 字条 认 双 直 -20 


| 图 1.3” 当 数字 遇 到 了 字符 串 
| 具体 步 又 如 下 : 
(1) 创建 PHP 脚本 ， 并 通过 echo 语句 输出 想 要 转换 的 变量 。 其 代码 如 下 


<2php 
$a=20; // 整 型 数据 
$b = "我 是 字符 串 型 数据 "; // 字 符 串 类 型 数据 
$e= $a+ $b; 
$f= $b + $a; 


echo "自动 类 型 转换 : <br>"; 

echo '20+ 我 是 字符 串 型 数据 =.$e."<br>"; 

echo "强制 类 型 转换 : <br>"; 

echo '20+ 我 是 字符 串 型 数据 =.(string)$e."<br>"; 


> 
| (2) 将 文件 存储 于 \MR\01\003\ 文 件 夹 下 ， 并 命名 为 mdexphp。 运 行 结果 如 图 1.3 所 示 。 
| 技术 要 点 


| 虽然 PHP 是 弱 类 型 语言 ， 但 有 时 仍然 需要 用 到 类 型 转换 。PHP 中 的 类 型 转换 和 C 语 
| 言 一 样 ， 非 常 简单 。 本 实例 的 关键 点 是 运用 类 型 转换 的 特点 进行 输出 。 
了 。4。 


多 学 两 招 : | 
(1 ) 转换 成 整 型 。 在 将 非 整 型 数据 转换 成 整 型 时 ， 方 法 是 在 变量 前 使 用 “(integer)” | 
或 “(int”。 转 换 规则 如 下 : | 

浮 点 型 转换 成 整 型 。 小 数 点 后 的 数 将 被 舍弃 ; 如 果 浮 点 数 超出 整数 取 值 范围 ， 那 么 将 | 
无 法 得 到 有 效 的 整 型 结果 ， 结 果 可 能 是 0 或 者 整 型 的 最 小 负数 。 | 

布尔 型 转换 成 整 型 。 那 么 true 值 将 转换 为 1，false 值 将 转换 为 0。 

字符 串 型 转换 为 整 型 。 将 会 对 字符 串 左 侧 的 第 一 位 进行 判断 。 如 果 第 一 位 是 数字 ,， 则 | 
从 第 一 位 开始 将 读 取 到 的 数字 转换 成 整 型 ; 如 果 第 一 位 不 是 数字 ， 则 结果 为 0。 | 

(2 ) 转换 成 浮 点 型 。 方 法 是 在 变量 前 使 用 “(float)”。 和 转换 规则 如 下 : 

整 型 转换 为 浮 点 型 。 其 结果 不 会 发 生变 化 。 

布尔 型 转换 为 浮 点 型 。 同 样 ，true 值 将 转换 为 1，false 值 将 转换 为 0。 | 

字符 囊 型 转换 为 浮 点 型 ,如 果 字符 囊 中 包含 小 数 点 “.” 或 科学 记 数 法 的 “e” 或 者 “EE” 
中 的 任何 一 个 字符 ， 则 字符 囊 被 当 作 浮 点 型 处 理 ， 否 则 ， 被 视 为 整 型 。 | 

(3 ) 转换 成 字符 串 型 。 方 法 是 在 变量 前 使 用 “(string)”。 转 换 规则 如 下 : 

整 型 或 者 浮 点 型 转换 成 字符 串 型 。 转 换 结 果 为 其 数值 。 

布尔 型 转换 为 字符 串 型 。true 值 将 转换 为 字符 串 “1”，false 值 将 转换 为 空 字 符 串 。 

对 象 或 数组 型 转换 成 字符 串 型 。 那 么 转换 结果 为 字符 串 对 象 或 字符 串 数组 。 | 

资源 型 转换 成 字符 串 型 。 转 换 结果 为 一 个 类 似 “Resource id#” 的 字符 串 。 在 “# 之 | 
后 是 PHP 在 运行 时 分 配给 该 资源 的 标识 代号 。 | 

(4) 转换 成 布尔 型 。 方 法 是 在 变量 前 使 用 “(boolean )” 或 “(bool)”。 因 为 布尔 型 只 | 
包含 两 个 值 : true 和 false， 所 以 其 转换 规则 包括 两 个 方面 : | 

第 一 方面 ， 转 换 结果 为 false 的 情况 。 

整 型 或 者 浮 点 型 数 0。 

空 字符 囊 和 字符 串 “0”。 

没有 任何 元 素 的 空 数组 。 

没有 任何 元 素 的 对 象 。 

特殊 类 型 “NULL”。 | 

第 二 方面 , 转换 结果 为 true 的 情况 . 排除 在 第 一 方面 说 明 的 情况 , 其 他 转换 结果 都 为 tue。 

(5 ) 转换 成 数组 。 方 法 是 在 变量 前 使 用 “( array )”。 转 换 规 则 是 : 将 非 数 组 型 转换 成 | 
与 原 变量 数据 类 型 相同 的 数组 ， 数 组 中 只 有 一 个 元 素 。 | 

(6) 转换 成 对 象 。 方 法 是 在 变量 前 使 用 “( object )”。 转 换 规则 是 : 将 非 对 象 型 转换 | 
成 一 个 新 的 对 象 ， 其 中 名 为 scalar 的 成 员 变量 将 包含 原 变量 的 值 。 | 


实例 004 通过 转 义 字符 输出 特殊 字符 串 


( 实例 位 置 : 配套 资源 \SL\01\004 视频 位 置 : 配套 资源 \SP\01\004 ) 


实例 说 明 
在 定义 长 字符 串 变 量 时 ， 往 往 字 符 串 本 身 包含 一 些 特殊 字符 ， 如 字符 串 本 身 包 含 双 引 
。5。 | 
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号 (“”), 这 时 就 需要 转 义 字符 对 特殊 字符 进行 转 义 。 


| 本 实例 通过 转 义 字符 “\” 转 义 经 特殊 字符 双 引号 PHPT 
本 图 1.4 使 用 转 义 字符 输出 特殊 字符 串 
”实现 过 程 
| 具体 步骤 如 下 : 

(1) 创建 PHP 脚本 文件 ， 并 通过 echo 语句 输出 经 转 义 字符 转 义 的 特殊 字符 串 。 其 代 
| 码 如 下 ; 
| <2php 

echo "\" 我 喜欢 PHP! \": // 输 出 转 义 字符 转 义 的 字符 串 
> 


(2) 将 该 文件 存储 于 \MR\01\004\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 1.4 


本 实例 的 关键 点 是 转 义 字符 “\” 的 使 用 。 它 除了 可 以 做 转 义 字符 外 ， 还 有 其 他 一 些 功 


| 能 ， 可 以 将 一 些 不 可 打印 字符 显示 出 来 ， 如 a、\b、\e、f、m、Y 和 Wt 等 。 


网 本 


指点 迷津 : 
转 义 字符 的 功能 只 有 一 个 ， 就 是 将 特殊 字符 转 义 成 普通 字符 。 


EY 005 通过 PHP5 新 型 字符 串 动态 输出 JavaScript 代码 


( 实例 位 置 配套 资源 \SL\01\005 视频 位 置 配套 资源 \SP\01\005 ) 


JavaScript 语言 是 一 门 功能 强大 的 客户 端 脚本 语 


| 言 ， 也 是 一 门路 平台 语言 。 PHP 支持 使 用 JavaScript 编 二 


码 。 本 实例 通过 PHP5 新 型 字符 串 动态 输出 JavaScript 
代码 ， 运 行 结果 如 图 1.5 所 示 。 


3 


图 1.5 动态 输出 JavaScript 代码 


实现 过 程 
创建 index.php 文件 ， 并 通过 PHP5 新 型 字符 串 实现 实例 。 其 代码 如 下 : 

<2php 

$str=<<<mark /PHP5 新 型 字符 串 开 始 部 分 

<script language="javascript" type="text/javascript"> //JavaScript 代码 
alert(" 欢 迎 进入 PHP 编程 世界 !!! "); // 输 出 提示 

</script> /结束 标记 

mark:; // 新 型 字符 串 结束 标记 

echo $str: // 输 出 字符 串 

?> 


技术 要 点 


PHP5 新 型 字符 串 的 使 用 是 本 实例 的 关键 。 PHP5 这 种 新 型 的 字符 串 是 以 “<<<” 开 始 ，， 
后 面 紧 跟 着 字符 串 开始 标记 , 之 后 为 字符 串 的 内 容 , 最 后 以 标记 加 分 号 (本 实例 以 “mark” | 会 内 
作为 结束 标记 ) 结束 。 本 函数 一 般 应 用 于 对 HTML 代码 的 格式 输出 。 I 
Ez 


实例 006 ”比较 两 个 时 间 改 的 大 小 


( 实例 位 置 : 配套 资源 \SL\01\006 视频 位 置 配套 资源 \SP\01\006 ) 


实例 说 明 
在 一 些 程序 中 经 常 需要 将 两 个 时 间 进 行 比较 ， 但 是 由 于 时 间 是 由 年 、 月 、 日 、 时 、 | 
分 、 秒 组 成 的 ， 比 较 起 来 很 不 方便 ， 这 时 可 以 把 时 间 转 换 成 时 间 蕉 来 进行 比较 。 本 实 | 
例 通过 date() 函 数 、strtotime() 函 数 和 ceil0 函 数 实现 比较 两 个 时 间 戳 的 大 小 ， 运 行 结果 如 | 
图 1.6 所 示 。 | 
1305012224 W2011-05-10 AI 
有 Ja 和 -05-05 odo000\ 
5 人 
图 1.6 ”比较 两 个 时 间 戳 的 大 小 


实现 过 程 
具体 步骤 如 下 : | 
(1) 创建 PHP 脚本 文件 。 首 先 对 PHP 语言 中 的 时 区 进行 设置 ， 将 时 区 更 改 为 中 国 上 | 
海 时 区 。 然 后 通过 strtotime0 函 数 获取 当前 时 间 的 UNIX 时 间 蕉 ， 并 与 指定 的 时 间 蕉 进行 | 
算术 运算 。 最 后 , 将 时 间 稚 运算 结果 转换 为 天 数 , 通过 ceil0 函 数 进行 取 整 运算 并 输出 结果 。 | 
其 代码 如 下 : 


<?php 
date default_ timezone set("Asia/ShangHai"); /将 格林 威 治 时 间 设 置 为 本 地 时 间 
$a = strtotime("now"): /取得 当前 时 间 惟 
$b = strtotime("05 May 2011"):; /取得 2011 年 5 月 S 号 的 时 间 戳 
echo $a."m'": 
echo "输出 日 期 "date("Y-m-d H:i:s",$a)."<br><br>"; /取得 以 $a 为 时 间 点 的 时 间 
echo $b."\n"; 
echo "输出 日 期 ".date("Y-m-d H:i:s",$b)."<br><br>"; // 取 得 以 $b 为 时 间 点 的 时 间 
$c = ceil(($a - $b)/(3600*24)): // 计 算 相 差 天 数 


echo " 距 2011 年 5 月 5 号 已 过 去 "Se" 天 " 
2> | 

(2) 将 该 文件 存储 于 \MR\01\006 文件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 1.6 

所 示 。 
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多 学 两 招 : 

有 效 的 时 间 惟 通常 从 Fri, 13 Dec 1901 20:45:54 GMT 到 Tue, 19 Jan 2038 03:14:07 
GMT (对 应 于 32 位 有 符号 整数 的 最 小 值 和 最 大 值 )。 不 是 所 有 的 平台 都 支持 负 的 时 间 稚 ， 
那么 日 记 范 围 就 被 限制 为 不 能 早 于 UNIX 纪元 。 这 意味 着 在 1970 年 1 月 1 日 之 前 的 日 期 
将 不 能 用 在 Windows、 某 些 Linux 版 本 以 及 几 个 其 他 的 操作 系统 中 。 


| 技术 要 点 


本 实例 主要 是 通过 strtotimeO 函 数 将 时 间 转 换 为 UNIX 时 间 蕉 ， 并 进行 相关 取 整 运算 


| 而 实现 的 。 其 中 涉及 相关 函数 语法 如 下 。 


(1) strtotime0) 函 数 ， 本 函数 预期 接受 一 个 包含 英文 日 期 格式 的 字符 串 并 尝试 将 其 解 


| 析 为 UNIX 时 间 鹤 。 


int strtotime( string time [, int now]); 
该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ， 如 果 


| 参数 time 的 格式 是 相对 时 间 , 其 对 应 的 时 间 就 是 参数 now 来 提供 的 ， 当 没有 提供 参数 now 
| 时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 失 败 ， 则 返回 false。 在 PHP5.1.0 之 前 的 版 本 中 ， 
| 本 函数 在 失败 时 返回 -1， 


脚下 留神 : 


(2) ceil0 函 数 : 返回 不 小 于 value 的 下 一 个 整数 。 


float ceil ( float value); 


在 UNIX 系统 中 ， 日 期 与 时 间 表 示 为 自 1970 年 1 月 1 日 零点 起 到 当前 时 刻 的 秒 数 ， 


这 种 时 间 称 为 UNIX 时 间 惟 , 以 32 位 二 进 制 表 示 。 其 中 , 1970 年 1 月 1 日 零点 称 为 UNIX 
| 世纪 元 。UNIX 时 间 蕉 提供 了 一 种 统一 、 简 洁 的 时 间 表 示 方 式 ， 在 不 同 的 操作 系统 中 均 支 


持 这 种 时 间 表 示 方式 , 同一 时 间 在 UNIX 和 Windows 中 均 以 相同 的 UNIX 时 间 稚 表示 ， 所 
以 不 需要 在 不 同 的 系统 中 进行 转换 。 同时 ，UNIX 时 间 蕉 是 一 个 时 间 差 ,与 时 区 没有 关系 ， 
无 论 当前 PHP 中 使 用 的 是 何 种 时 区 ， 其 UNIX 时 间 鹤 都 是 唯一 的 。 


实例 007 判断 数字 的 奇偶 性 


( 实例 位 置 配套 资源 \SL\01\007 视频 位 置 : 配套 资源 \SP\O1\007 ) 


实例 说 明 
条 件 运算 符 是 进行 或 真 或 假 运算 的 。 本 实例 通过 三 元 运算 来 演示 如 何 用 三 元 运算 符 判 
断 数字 的 奇偶 性 ， 运 行 结果 如 图 1.7 所 示 。 


0 是 俩 数 ] 是 奇数 2 是 傅 孝 3 是 奇数 
,5 是 寺 数 人权 7 是 凋 数 8 是 但 数 


图 1.7 用 三 元 运算 符 判断 数字 的 奇偶 性 


。8 。 
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We 
实现 过 程 
具体 步骤 如 下 : 


(1) 创建 PHP 脚本 文件 。 首 先 ， 通 过 for 循环 语句 循环 输出 0 一 9 的 10 个 数字 。 然 ， 
后 ,将 得 到 的 10 个 数字 分 别 与 2 做 求 余 运算 并 将 运算 结果 作为 三 元 运算 的 条 件 进行 判断 。 | 区 


最 后 ， 将 判断 的 结果 利用 echo0 语 句 输出 出 来 。 其 代码 如 下 : 
<2php | 
/做 小 于 10 的 循环 


for($a = 0:$a < 10:$at+){ 
/用 三 元 运算 输出 ， 如 果 没 有 余数 则 是 偶数 ， 否 则 为 奇数 
echo $a%2 一 0? $a." 是 偶数 "."\n" : $a." 是 奇数 "."\n"; 
} 


> | 
(2) 将 该 文件 存储 于 \MRMOIV007\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 1.7 | 
所 示 。 | 
技术 要 点 | 
本 实例 通过 三 元 运算 符 判断 数字 的 奇偶 性 ， 并 且 判断 数字 奇偶 性 时 使 用 了 求 余 运算 | 
符 。 当 期 望 数字 与 2 做 除法 运算 时 ， 如 果 存 在 余数 〈 即 不 能 被 2 整除 )， 为 奇数 ， 否 则 为 | 
偶数 。 三 元 运算 符 的 语法 如 下 : | 
(expr) ? {statementl;} : {statement2;} 
三 元 运算 符 与 过 ..else.… 函 数 实现 的 功能 完全 相同 。 


实例 008 通过 远 辑 运算 符 判 新 用 户 的 权限 


( 实例 位 置 : 配套 资源 \SL\01\008 视频 位 置 配套 资源 \SP\01\008 ) 


实例 说 明 | 
逻辑 运算 符 往 往 作为 迁 等 语句 的 条 件 出 现 ， 它 有 很 多 种 而 且 功能 也 各 不 相同 。 本 实例 
介绍 逻辑 运算 符 的 语法 等 相关 知识 ， 并 通过 逻辑 运算 符 来 演示 用 户 是 否 具 有 后 台 管 理 权 | 
限 ， 运 行 结果 如 图 1.8 和 图 1.9 所 示 。 | 
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亲 扬 周 页 的 沿 忌 
GO wudpe 一 证 
Lb- > 


EC 


图 1.8 后 台 管 理 权限 图 1.9 不 具有 后 台 管理 权限 
实现 过 程 
具体 步 又 如 下 : | 
(1) 创建 PHP 脚本 文件 。 首 先 ， 编 写 <form> 表 单 ， 并 将 表单 中 method 方法 定义 为 | 
Ss Le 
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POST。 然 后 ， 当 单 击 按钮 时 ， 将 POST 方法 接收 的 用 户 名 和 密码 进行 逻辑 与 运算 。 当 让 
语句 的 结果 为 true 时 输出 “您 具有 管理 员 权 限 ” 的 提示 ， 和 否则 输出 “您 非 权 限 用 户 ” 的 提 
示 。 其 代码 如 下 : 
<?php 
echo "<form action="method='post>"; // 输 出 表单 


echo "用 户 名 : <input type='text name='text><br>"; 
echo " 密 &nbsp;&nbsp: 码 : <input type='password' name= pwd>"; 
echo "<input type='submit name='sub' value 一 确定 >": 
echo "</form>"; 
ifisset($_ POST['sub])){ // 通 过 post 方式 提交 
这 $_ POST[text] 一 "mr" &&$ POST[pwd] 一 "mrsoft){ /验证 用 户 名 密码 
echo "<script>alert(' 您 具有 管理 员 权限 ”);</script>"; /符合 条 件 输出 提示 
Jelse{ 
echo "<script>alert( 您 非 权 限 用 户 );</script>"; // 不 符合 条 件 输 出 提示 
} 
} 


J 


(2) 将 该 文件 存储 于 \MR\01\008\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 1.8 


| 和 图 1.9 所 示 。 


| 多 学 两 招 ， 


如 果 在 涉及 到 运算 符 的 优先 级 时 不 想 总 查找 优先 级 表 而 本 身 又 记忆 不 清 时， 建议 使 用 


| 小 括号 把 起 要 先 运算 的 表达 式 括 超 来， 这 样 问题 就 迎 妨 而 解 了 。 


本 实例 主要 是 通过 逻辑 运算 符 && (逻辑 与 ) 将 从 表单 中 利用 POST 方法 取得 的 由 文 


本 框 输入 的 用 户 名 和 密码 联系 起 来 ， 用 户 名 和 密码 必须 同时 为 真 时 ， 让 语句 的 结果 才 会 为 
| 真 ， 反 之 为 假 。 


实例 009 获取 2000~2020 年 中 所 有 的 头 年 


( 实例 位 置 配套 资源 \SL\01\009 视频 位 置 : 配套 资源 \SP\01\009 ) 


| 实例 说 明 


在 PHP 语言 中 为 了 提升 编程 效率 设置 了 一 ea 
些 自 增 自 减 运 算 符 , 这 种 运算 符 在 循环 语句 中 得 人 
到 广泛 应 用 。 本 实例 简要 介绍 了 自 增 自 减 运 算 符 


ROSA RN 
i We Ee “2000 “2004,3008. 2012 2016 2020 
并 通过 自 增 自 减 运算 符 修饰 的 变量 来 演示 它 的 SE RO 


应 用 ， 运 行 结果 如 图 1.10 所 示 。 图 1.10 获取 2000 一 2020 年 中 所 有 的 半年 
实现 过 程 


创建 index.php 文件 。 首先 , 利用 for 循环 定义 循环 变量 , 将 变量 的 初始 值 设置 为 2000， 
*。10 。 
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最 大 值 小 于 2020, 并 是 要求 变量 做 自 增 运 算 。 然后, 设置 循环 变量 与 4 做 求 余 运 算 。 最 后 ， 
把 符合 条 件 的 数值 通过 echo 语句 输出 。 其 代码 如 下 : | 


<2php 


if($ POST[sub]){ // 通 过 post 接收 参数 
for($a = 2000;$a <= 2020;$at+t){ // 通 过 循环 定义 循环 变量 
这 $a% 4 一 0){ /将 循环 变量 与 4 做 求 余 运 算 
echo $a."&nbsp;&nbsp;"; /输出 循环 变量 
} 
} 
} 
ie 
技术 要 点 


递增 或 递减 运算 符 有 两 种 使 用 方法 : 一 种 是 先 将 变量 增加 或 减少 1 后 再 将 值 赋 给 原 变 | 
量 ， 称 为 前 置 递增 或 递减 运算 符 ( 也 称 前 置 自 增 自 减 运算 符 )， 另 一 种 是 将 运算 符 放 在 变 | 
量 后 面 ， 即 先 返回 变量 的 当前 值 ， 然 后 将 变量 的 当前 值 增加 或 减少 1， 称 为 后 置 递增 或 递 | 
减 运 算 符 ( 后 置 自 增 自 减 运算 符 )。 本 实例 将 递增 递减 运算 符 应 用 到 for 循环 的 变量 之 中 ， | 
利用 变量 的 变化 完成 期 望 次 数 的 循环 。 


实例 010” 自 定义 数字 加 窗 算 法 


( 实例 位 置 : 配套 资源 \SL\01\010 视频 位 置 配套 资源 \SP\01\010 ) 


例 说 明 


位 运算 符 也 是 PHP 运算 符 中 不 可 或 缺 的 一 部 分 。 本 实例 通过 位 运算 符 实现 对 数字 进行 
加 密 ， 运 行 结果 如 图 1.11 和 图 1.12 所 示 。 | 


Bheey/192168119%/SU01/010/- win. al ul 


图 1.11 使 用 位 运算 符 对 数字 进行 加 密 图 1.12 使 用 位 运算 符 对 数字 进行 解密 
实现 过 程 

具体 步骤 如 下 : 

(1) 创建 PHP 脚本 文件 。 首 先 ， 编写 <form> 表 单 并 定义 常量 ， 将 数值 3.1415926 赋 | 

给 常量 PI。 然 后 ， 定 义 自 定义 函数 ， 在 函数 体内 部 将 文本 框 信息 与 常量 PI 做 移 位 运算 并 | 

返回 结果 。 最后, 通过 提交 数据 和 单 击 按钮 实现 输出 加 密 、 解 密 算法 的 结果 。 其 代码 如 下 : | 

<2php EDEL | 


echo "<form action=" method= post>": 
echo "数字 口令 : <input name='text type='text>"; 


i L_ 
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echo "<input type='submit name='sub' value 一 确定 >": 
echo "</form>"; 
define("PI",3.1415926): // 定 义 常量 
function Encrypt($str){ // 自 定义 加 密 算 法 
Tetum $str = $str << PI; 
} 
function Decrypt($str){ // 自 定义 解密 算法 
Tetum $str = $str >> PI:; 
} 
if($ POST[sub){ // 通 过 post 方式 传 参数 
echo "加 密 口令 &nbsp;&nbsp:;".Encrypt($_POST[text)."<br>"; /输出 口令 
$_SESSION[pwd] = Encrypt($_ POST[text); /将 口令 保存 在 SESSION 中 
?> 
<a href='index.php?pwd=1> 解 密 口令 </a> // 超 链接 
<?php 
} 
ifisset($_GET[pwd])){ // 判 断 地 址 栏 是 否 存 在 此 参数 
echo "解密 口令 &nbsp;&nbsp;".Decrypt($_SESSION[pwd]); // 输 出 解密 结果 
} 
?> 


(2) 将 该 文件 存储 于 \MR\01\010\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 1.11 
和 图 1.12 所 示 。 


多 学 两 招 : 

位 运算 符 允许 对 整 型 数据 中 指定 的 位 进行 置 位 。 如 果 左 右 参 数 都 是 字符 串 ， 则 位 运算 
符 将 操作 字符 的 ASCII 值 。 
技术 要 点 

位 运算 符 是 指 对 二 进 制 位 从 低 到 高 位 对 齐 后 进行 运算 。 在 PHP 中 的 位 运算 符 如 表 1.2 
所 示 。 本 实例 中 ， 利 用 自 定义 函数 ， 将 文本 框 信息 与 定义 的 常量 做 指定 的 位 运算 ， 并 返 
计算 结果 ， 从 而 将 文本 框 信息 进行 加 密 或 解密 处 理 。 


回 


表 1.2 位 运算 符 


用 举 


& 按 位 与 按 位 取 反 Sm~$n 
| 按 位 或 向 左 移 位 Sm<<$n 


实例 011 随机 输出 字符 串 


( 实例 位 置 : 配套 资源 \SL\01\011 视频 位 置 : 配套 资源 \SP\01\011 ) 


向 右 移 位 


$m>>$n 


实例 说 明 


在 应 用 字符 串 时 往往 需要 将 两 个 字符 串 进 行 连接 ， 这 时 可 以 使 用 字符 串 运 算 符 。 本 实 
。12。 


例 通过 字符 串 运算 符 打印 随机 组 合生 日 祝福 语 ， 运 行 有 
结果 如 图 1.13 所 示 。 ER 


图 1.13 打印 随机 组 合生 日 祝福 语 


实现 过 程 | 
创建 index.php 文件 。 首 先 ， 定 义 两 个 数组 ， 将 字符 串 信 息 保存 在 数组 之 中 。 然 后 ， | 屋内 


利用 rand 函数 随机 取得 数组 中 的 两 条 信息 保存 在 变量 中 。 最 后 ， 通 过 echo 语句 输出 用 连 
接 运 算 符 连 接 的 变量 。 其 代码 如 下 : | 


<2php 
$ar= array(" 生 日 快乐 "," 今 天 是 你 的 出 生日 "," 同 学 们 为 你 许愿 "); // 定 义 数 组 | 
$array = array(" 祝 你 万 事 如 意 "," 祝 你 生日 快乐 "," 祝 你 福 如 东海 长 流水 寿 比 南山 不 老 松 ");// 定 义 | 
数组 | 
S$rand = rand(0,2); // 定 义 随机 数 
echo $ar[$rand].$array[$rand]; // 输 出 字符 串 
ye 
脚下 留神 : 


用 过 CC 或 Java 的 读者 应 该 注意 ， 这 里 的 “1” 号 只 作为 算术 运算 符 使 用 ， 而 不 能 作为 | 
字符 囊 运算 符 。 
技术 要 点 | 

字符 串 可 以 用 “.” (点) 字符 串 连 接 符 连 接 ， 它 可 以 把 两 个 或 两 个 以 上 的 字符 串 连 接 | 
成 一 个 新 的 字符 串 。 字 符 帅 的 连接 有 两 种 形式 第 一 种 是 连接 运算 符 “.”， 第 二 种 是 连接 | 
赋值 运算 符 “=”。 在 实际 的 程序 开发 中 ， 两 种 连接 方式 都 非常 常用 。 | 


实例 012 在 页 面 中 打印 服务 器 时 间 


( 实例 位 置 : 配套 资源 \SL\01\012 视频 位 置 : 配套 资源 \SP\01\012 ) 


实例 说 明 | 
在 用 PHP 编写 的 网 站 中 ,我 们 经 常 需要 获取 当前 时 间 。 例 如 ,用户 在 什么 时 间 登 录 的 

网 站 ， 黑 客 攻击 网 站 是 在 什么 时 间 等 。 本 实例 应 | 

用 PHP 标记 通过 echo 语句 和 date0) 函 数 来 实现 获 汉 

取 服 务 器 时 间 ， 并 进行 打印 ， 运 行 结果 如 图 1.14 图 1.14 系统 当前 时 间 


系统 的 当前 时 间 是 ; 2000.0001 I0t03000 | 


所 示 。 
实现 过 程 
创建 index.php 文件 ， 并 通过 echo 语句 输出 date0 函 数 的 返回 值 。 其 代码 如 下 : 
<?php 
echo date(Y-m-s H:i:s'); /输出 当前 时 间 
we 
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| 技术 要 点 
| 本 实例 主要 是 通过 date0 函 数 获取 系统 的 格林 威 治 时间 。 其 语法 说 明 如 下 : 
| date(string format,int timestamp); 


其 中 参数 format 指定 日 期 和 时 间 输 出 的 格式 。 有 关 参 数 format 指定 的 格式 如 表 1.3 
| 所 示 。 参 数 timestamp 为 可 选 参数 ， 指 定时 间 蕉 ， 如 果 没 有 指定 时 间 惟 ， 则 使 用 本 地 时 
| 间 time0。 

表 1.3 ”参数 format 的 格式 化 选项 

| _ 参 数 说 了 明 

| 小 写 的 上 午 和 下 午 值 ， 返 回 值 am 或 pm 

大 写 的 上 午 和 下 午 值 ， 返 回 值 AM 或 PM 

Swatch Internet 标准 时 间 ， 返 回 值 000 一 999 

月 份 中 的 第 几 天 ， 有 前 导 零 的 2 位 数字 ， 返 回 值 01 一 31 

星期 中 的 第 几 天 ， 文 本 格式 ，3 个 字母 ， 返 回 值 Mon 一 Sun 

月 份 ， 完 整 的 文本 格式 ， 返 回 值 January 一 December 

小 时 ，12 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 1 一 12 

小 时 ，24 小 时 格式 ， 没 有 前 导 零 ， 返 回 值 0 一 23 

有 前 导 零 的 分 钟 数 ， 返 回 值 00 一 59 

判断 是 否 为 夏令 时 ， 返 回 值 如 果 是 夏令 时 为 1， 否则 为 0 

月 份 中 的 第 几 天 ， 没 有 前 导 零 ， 返 回 值 1 一 31 

星期 数 ， 完 整 的 文本 格式 ， 返 回 值 Sunday 一 Saturday 

判断 是 否 为 闽 年 ， 返 回 值 如 果 是 闽 年 为 1， 否则 为 0 

数字 表示 的 月 份 ， 有 前 导 零 ， 返 回 值 01 一 12 

3 个 字母 缩写 表示 的 月 份 ， 返 回 值 Jan 一 Dec 

数字 表示 的 月 份 ， 没 有 前 导 零 ， 返 回 值 1 一 12 

与 格林 威 治 时 间 相 差 的 小 时 数 ， 如 0200 

RFC 822 格式 的 日 期 ， 如 Thu，21 Dec 2000 16: 01: 07 +0200 

秒 数 ， 有 前 导 零 ， 返 回 值 00 一 59 

每 月 天 数 后 面 的 英文 后 级 ， 两 个 字符 ， 如 st、nd、rd 或 也 。 可 以 和 j 一 起 使 用 

指定 月 份 所 应 有 的 天 数 

本 机 所 在 的 时 区 

从 UNIX 纪元 (January 1 1970 00:00:00 GMT) 开始 至 今 的 秒 数 

星期 中 的 第 几 天 ， 数 字 表示 ， 返 回 值 为 0 一 6 

ISO-8601 格式 年 份 中 的 第 几 周 ， 每 周 从 星期 一 开始 

2 位 数字 表示 的 年 份 ， 返 回 值 如 88 或 08 

4 位 数字 完整 表示 的 年 份 ， 返 回 值 如 1998、2008 

年 份 中 的 第 几 天 ， 返 回 值 0 一 366 

时 差 偏 移 量 的 秒 数 。UTC 西边 的 时 区 偏 移 量 总 是 负 的 ，UTC 东边 的 时 区 偏 移 量 总 是 正 

的 ， 返 回 值 : -43200 一 43200 


N < kalaslelplrloppPiep 攻 BIRD > 


N 
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实例 013 区 分 单 引 号 和 双 引 号 


( 实例 位 置 : 配套 资源 \SL\01\013 视频 位 置 配套 资源 \SP\01\013 ) 


实例 说 明 
输出 或 定义 字符 串 时 离 不 开 单 引 号 和 双 引 号 的 修饰 ， 表 人 
面 上 看 它们 似乎 没有 什么 不 同 ， 实 际 上 它们 是 有 区 别 的 。 本 条 出 字符 市 4a 


实例 应 用 单 引 号 与 双 引 号 操作 符 向 用 户 说 明 如 何 区 分 单 引 号 
和 双 引 号 ， 运 行 结果 如 图 1.15 所 示 。 
实现 过 程 
创建 index.php 文件 ， 并 通过 echo 语句 输出 用 单 双 引 号 修饰 的 字符 串 。 其 代码 如 下 
<2?php 
$a= 1; 
echo "输出 字符 串 $a"."<br>"; 


echo ' 输 出 字符 串 $a'; 
?> 


图 1.15 区 分 单 引号 和 双 引 号 | 


技术 要 点 


本 实例 的 关键 点 是 输出 单 引号 和 双 引 号 修饰 的 字符 串 以 显示 其 区 别 。 | 
使 用 双 引 号 与 单 引号 最 大 的 区 别 是 : 双 引 号 中 所 包 全 的 变量 会 自动 被 天 换 成 实际 数 | 
值 ， 而 在 单 引号 中 包含 的 变量 则 按 普 通 字符 串 输 出 。 | 


实例 014 ”前 置 运 算 答 和 后 置 运 算 符 的 区 别 
( 实例 位 置 : 配套 资源 \SL\01\014 视频 位 置 配套 资源 \SP\01\014 ) 
说 昌 
前 置 运算 符 与 后 置 运算 符 ， 大 多 用 在 循环 语句 中 。 本 实例 应 用 自 增 自 减 运算 符 修饰 的 | 
变量 通过 显示 结果 来 说 明 前 置 运算 符 与 后 置 运算 符 的 区 别 ， 运 行 结果 如 图 1.16 所 示 。 | 


~ 后 本 加 运 复 
012345678910 


109876543210 


图 1.16 前 置 运算 符 与 后 置 运算 符 区 别 
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”实现 过 程 
具体 步骤 如 下 : 
全 内 。 (1) 创建 PHP 脚本 文件 ， 首 先 ， 通 过 for 循环 语句 定义 循环 变量 。 然 后， 


语句 输出 循环 变量 。 其 代码 如 下 : 


$a=0; // 自 定义 变量 并 给 定 初始 值 
echo ". 后 置 加 运算 ---------<br>"; 
for($b = 0;$b <= 10;$b++){ // 使 用 for 循环 语句 
eoho Farr // 使 用 后 置 运 算 符 
} 
echo "<br>---------- 前 置 加 运算 ---------<br>"; 
$d=0; 
for($b = 0;$b <= 10;$b++){ 
echo ++$d." "; // 使 用 前 置 运算 符 
} 
echo "<br>---------- 前 置 减 运算 ---------<br>"; 
$f =10; 
for($b = 10:$b >= 0:$b--){ 
echo --$f." "; // 使 用 前 置 运 算 符 
} 
echo "<br>---------- 后 置 减 运算 ---------<br>"; 
$g =10; 
for($b = 10;$b >= 0:$b--){ 
echo $g--." "; // 使 用 后 置 运 算 符 
} 


?> 


通过 echo 


(2) 将 该 文件 存储 于 \MR\01\014\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 1.16 


| 所 示 。 
| 技术 要 点 


本 实例 的 关键 点 是 自 增 自 减 运算 符 的 灵活 运用 。 在 使 用 前 置 减 运算 符 时 ， 要 注意 给 定 


| 的 初始 值 ， 否 则 会 出 现 本 例 的 问题 ， 前 置 减 运算 输出 负数 。 


实例 015 使 用 可 灾变 量 输 出 “I Like PHP!” 


( 实例 位 置 配套 资源 \SL\01\015 视频 位 置 : 配套 资源 \SP\01\015 ) 


实例 说 明 
| 。。 变量 包括 预定 义 变量 、 可 变 变量 等 。 木 实例 通过 可 变 变量 实 
| 结果 如 图 1.17 所 示 。 


I Like PHP! 
| 图 1.17 使 用 可 变 变量 输出 
了 本 | 到 


现 输出 指定 字符 


第 1] 章 PHP 基础 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 一 个 字符 串 变量 。 然 后 ， 将 第 一 个 字符 串 变 量 | 


的 值 前 加 个 “$” 作 为 第 二 个 变量 的 变量 名 。 最 后 ， 通 过 echo 语句 输出 可 变 变 量 。 其 代码 | 
如 下 : 


<2?php 
$str name= "str_ name 1"; // 定 义 变量 
$str name 1 = "I Like PHP!"; // 定 义 可 变 变 量 
echo $$str name; // 输 出 可 变 变量 
?> 


(2) 将 该 文件 存储 于 \MRYOI\015\ 文 件 夹 下 ， 并 命名 为 indexphp。 运 行 结果 如 图 117 | 
所 示 。 


技术 要 点 


可 变 变 量 是 一 种 独特 的 变量 ， 它 允许 动态 改变 一 个 变量 名 称 。 工 作 原 理 是 该 变量 的 名 
称 由 另外 一 个 变量 的 值 来 确定 。 实 现 过 程 是 在 变量 的 前 面 多 加 一 个 “$”。 | 


二 UD 


本 章 读者 可 以 学 到 如 下 实例 : 


豆 于 于 于 于 于 苇 于 于 芋 


各 各 有 


豆 于 瑟瑟 至 
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论坛 内 容 的 简单 输出 
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中 文 图 像 验 证 码 

上 传 文件 到 服务 器 

读 取 整 个 文本 文件 中 的 内 容 
连接 MySQL 数据 库 服务 器 
选择 指定 的 MYSQL 数据 库 
执行 SQL 语句 

文本 文件 分 页 读 取 

查询 关键 字 描 红 
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实例 016“ 自 定义 函数 过 滤 字 符 事 


( 实 便 位置 : 配套 资源 \SL\02\016 视频 位 置 : 配套 资源 \SP\02\016 ) 


实例 说 明 
用 户 在 论坛 上 发 表 留 言 或 者 回复 时 可 能 会 遇 
到 这 种 情况 : 单 击 “发 布 ”按钮 时 ， 系 统 提示 使 用 
了 禁用 词语 禁止 发 布 。 这 是 论坛 的 开发 人 员 为 了 规 
范 论坛 而 采用 的 过 滤 字 符 串 的 手段 。 本 实例 通过 自 
定义 函数 实现 过 滤 字 符 串 ,运行 结果 如 图 2.1 所 示 。 Pa 
实现 过 程 图 2.1 自 定义 函数 过 滤 字 符 串 
具体 步骤 如 下 : | 
(1) 创建 名 称 为 index 的 PHP 文件 ， 并 自 定义 具有 过 滤 功 能 的 验证 函数 。 首 先 ， 将 | 
禁用 词语 保存 在 数组 中 ， 并 通过 分 割 函数 将 数组 拆 分 。 然 后 ， 应 用 正则 表达 式 函 数 对 禁用 | 
词语 进行 判断 。 当 用 户 输入 内 容 中 包含 禁用 词语 时 ， 会 执行 屏蔽 操作 。 该 过 滤 功 能 是 通过 | 
当 单 击 “ 提 交 ” 按 钮 时 ， 调 用 PHP 的 自 定义 函数 来 实现 的 。 最 后 ， 通 过 JavaScript 输出 提 | 
示人 信息。 其 代码 如 下 : | 
<2php 
function str($str){ // 自 定义 函数 
$array 二 array(' 图 书 ', 明 日 科技 ,软件 ,编程 词典 ,编程 ,' 词 典 ); /数组 转换 为 字符 串 
S$repstr = implode($array); 


if(preg_match("/$str/",S$repstr)) { /正则 表达 式 验 证 字符 串 
echo "<script>alert( 您 使 用 了 禁用 词语 ， 请 重新 填写 ");location href='index.php'</script>"; 
}else{ 
echo "内 容 为 :".$str; // 输 出 字符 串 
} 
} 
ift!empty($_POST['sub]){ 
str($_POST['te']); // 调 用 自 定义 函数 
?> 


(2) 将 该 文件 存储 于 \MRMAO2W01\ 文 件 夹 下 ， 并 在 浏览 器 中 输入 http:/127.0.0.lmn | 
02/001 浏览 文件 。 | 


脚下 留神 : | 

在 判断 是 否 存在 以 POST 方式 传递 的 URL 参数 时 ， 如 果 直 接应 用 判断 该 传递 参数 是 否 存 | 

在 ， 系 统 可 能 会 给 出 未 定义 的 警告 提示 。 为 了 避免 得 到 非 预 期 结果 ， 这 里 应 用 empty0 函 数 判 | 

断 该 传递 参数 是 否 存在 。 | 

技术 要 点 | 

本 实例 通过 创建 自 定义 函数 sr0 对 字符 串 进行 过 滤 。 如 果 出 现 指定 的 关键 词 ， 则 给 出 | 
Se UD 
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提示 信息 ， 并 终止 程序 执行 。 自 定义 函数 str 的 结构 如 下 : 


function str($str){ 
$array 二 array(' 图 书 ',' 明 日 科技 ,软件 ,编程 词典 ,编程 ,词典 ); /定义 数组 
Srepstr = implode($array); // 数 组 转换 成 字符 串 
if(preg_match("/$str/",$repstr)){ // 正 则 表达 式 验 证 字符 串 
echo "<script>alert(' 您 使 用 了 禁用 词语 ， 请 重新 填写 ');location.href='index.php'</script>"; 
}else{ 
echo "内 容 为 :".$str; // 输 出 数据 
} 
} 
| 多 学 两 招 : 


本 实例 只 是 简单 地 介绍 了 字符 串 过 滤 的 原理 ， 真 正 的 过 小 程序 由 于 数据 量 较 大 ， 需 要 将 


| 雪 扣 在 储 在 妆 据 库 之 由 如 果 读者 感 兴趣 ， 可 以 将 其 与 数据 库 中 的 数据 结合 进行 使 用 。 


实例 017 获取 上 传 文件 的 后 缀 


( 实例 位 置 : 配套 资源 \SL\02\017 视频 位 置 配套 资源 \SP\02\017 ) 


实例 说 明 


件 上 传 对 于 服务 器 来 说 具有 很 大 风险 ， 应 该 对 文件 大 小 、 文 
| 件 类 型 进行 限制 ,本 实例 通过 字符 串 函数 strevO 获 取 上 传 文 


| 实现 过 程 


文件 上 传 功能 几乎 是 所 有 网 站 所 必需 的 模块 。 然 而 ， 文 


| 件 的 后 绥 ， 运 行 结果 如 图 2.2 所 示 。 


图 2.2 ”获取 上 传 文件 的 后 乡 
具体 步骤 如 下 : 
(1) 创建 名 称 为 index 的 PHP 脚本 文件 。 当 用 户 单 击 “ 上 传 ” 按钮 时 ， 首 先 利 用 post 


| 方法 接收 文本 框 中 的 信息 ， 其 次 利用 反 转 函数 将 文本 框 信息 数据 进行 反 转 ， 并 利用 字符 串 
| 拆 分 函数 explodeO 以 “. “-.” 作 为 分 隔 符 进行 分 割 ， 然 后 将 分 割 后 的 结果 保存 在 数组 之 中 ,最 


| 后 将 指定 数据 再 次 反 转 ， 输出 已 取得 上 传 文件 的 后 级 名 称 。 其 代码 如 下 : 


hp 

fl!empty($_ POST["sub"])){ // 通 过 post 方式 传递 参数 
$a = strrev($_ POST[text]): // 反 转 字符 串 
$b = explode(".",$a); // 以 点 号 分 割 
$c = strrev($b[0]); // 反 转 字 符 串 
echo "文件 后 级 为 :.$c"; // 输 出 文件 后 级 

} 

?> 


(2) 将 该 文件 存储 于 \MR\02\002\ 文 件 夹 下 ， 并 在 浏览 器 中 输入 http://127.0.0.1/mr/02/ 
002 浏览 文件 。 


*。20 。 


PHP 中 字符 串 的 逆序 输出 可 以 通过 循环 实现 ， 但 最 简单 的 方式 是 通过 函数 strrev0 实 

现 。strrevO 函 数 用 于 将 字符 串 反 转 。 其 语法 如 下 : | 
string strrev ( string string ): 

参数 string string 为 需要 反 转 的 字符 串 。 | 

在 本 实例 中 , 通过 strrev0 函 数 对 上 传 文件 的 名 称 进行 反 转 输出 ， 并 通过 explodeO 函 数 | 

以 “.” 为 分 隔 符 ， 对 文件 名 称 进行 分 割 ， 然 后 再 次 应 用 strrev0 函 数 对 数组 中 的 第 一 个 元 | 

素 值 进行 返回 输出 ， 获 取 到 的 就 是 上 传 文件 的 后 级 。 | 


多 学 两 招 : | 
利用 strev0 函 数 达到 检索 字符 事 的 目的 相对 较 麻烦 ， 可 以 使 用 正则 表达 式 函 数 preg | 


实例 018 统一 上 传 文件 名 称 的 大 小 写 


( 实例 位 置 : 配套 资源 \SL\02\018 视频 位 置 : 配套 资源 \SP\02\018 ) 


实例 说 明 

统一 上 传 文件 名 称 的 大 小 写 是 十 分 必要 的 。 例 如 ， 
上 传 图 片 文件 imgjpg 和 Img.jpg， 如 果 文 件 名 称 未 经 
大 小 写 统一 则 上 传 时 可 能 就 不 会 出 现 覆 盖 提 示 。 本 实 


例 通 过 字符 串 函 数 strtoupper()、strtolower0) 实 现 统一 上 人 
传 文件 名 称 的 大 小 写 ， 运 行 结果 如 图 2.3 所 示 。 4 
次 现 过 程 


图 2.3 统一 上 传 文件 名 称 的 大 小 写 
具体 步骤 如 下 ; | 
(1) 创建 名 称 为 index 的 PHP 脚本 文件 。 当 用 户 单 击 “上传 ”按钮 时 ， 处 理 页 分 别 | 

利用 转换 小 写 和 大 写 的 函数 strtolowerO 、strtoupper( 将 接收 到 的 文本 框 的 信息 进行 对 应 的 | 

大 小 写 转换 ， 并 输出 转换 结果 。 其 代码 如 下 : | 


<2php 
session start(); 
这 !empty($_POST["sub"])){ // 通 过 post 方式 传递 参数 

$a = strtoupper($_ POST["text"]); // 转 换 为 大 写 
echo "文件 名 称 自动 转换 为 大 写 : ".$a."<br>": // 输 出 
$b = strtolower($_POST["text"]): /| 转换 为 小 写 
echo "文件 名 称 自动 转换 为 小 写 : ".$b; // 输 出 

> ， 
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(2) 将 该 文件 存储 于 \MR\02\003\ 文 件 夹 下 ， 并 在 浏览 器 中 输入 http://127.0.0.1/mr/ 
02/003 浏览 文件 。 


脚下 留神 : 
session start0 开 局 会 话 是 不 能 省 略 的 。 如 果 该 语句 缺少 ， 则 在 程序 运行 时 可 能 得 不 到 预期 
结果 ， 或 在 显示 页 面 出 现 错误 。 


| 技术 要 点 


| 多 学 两 招 


实现 字符 串 的 大 小 写 转换 ， 主 要 通过 strtolower0 和 strtoupper() 函 数 。 
(1) strtolower(): 转换 为 小 写 。 
string strtolower ( string str ) 
(2) strtoupper0: 转换 为 大 写 。 
string strtoupper ( string string ) 


参数 string 为 需要 转换 的 字符 串 。 


在 电子 商务 类 网 站 的 后 台 商品 添加 页 面 中 ， 为 了 使 商品 的 型 号 以 统一 的 规格 显示 ， 经 党 


| 会 利用 大 小 写 转换 函数 ， 所 以 掌握 这 两 个 函数 是 很 有 必要 的 。 


实例 019 ”论坛 内 容 的 简单 输出 


( 实例 位 置 : 配套 资源 \SL\02\019 视频 位 置 : 配套 资源 \SP\02\019 ) 


| 实例 说 明 


| 回 车 符 ， 因 为 不 是 所 有 的 论坛 用 户 都 知晓 HTML 


开发 论坛 程序 很 重要 的 一 点 是 转换 空格 符 和 


| 标签 “&nbsp: 和 <br> 的 作用 ， 大 多 数 用 户 都 喜欢 用 | 

| 空格 键 和 回 车 键 对 文本 进行 控制 , 这 就 需要 程序 员 ns: 耻 本 

| 人 为 地 做 到 统一 。 下 面 我 们 通过 自 定义 函数 定义 转 到 a 

| 换 方 法 实现 论坛 内 容 的 简短 输出 , 运行 结果 如 图 2.4 本 天 

| 所 示 。 

| I 

| 实现 过 程 图 2.4 论坛 内 容 的 简短 输出 
| 具体 步骤 如 下 : 


(1) 创建 PHP 脚本 文件 ， 并 通过 创建 自 定义 函数 str0 对 空格 符 和 回 车 符 进 行 蔡 换 。 


当 用 户 单 击 “ 提 交 ” 按 钮 时 ， 处 理 页 首先 对 文本 框 是 否 存 在 内 容 进行 判断 ， 如 果 文 本 框 内 


容 不 为 空 ， 则 调用 自 定义 函数 并 输出 文本 信息 。 其 代码 如 下 : 


。22 。 
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c 


<?php 
function str($str){ // 自 定义 函数 
$str = preg_replace("/ /","&nbsp:".$str): // 替 换 空格 符 
S$str = preg_replace("/cha(13)/","<br>",$str); 1/ 替换 回 车 符 
echo "内 容 : ".$str; // 输 出 
1 
这 !empty($_POST["sub"])){ // 通 过 post 方式 传递 参数 


/如 果 text 为 空 或 者 文本 域 和 下 拉 列 表 框 同 时 为 空 
这 $_ POST["text"] == "" || (($_POST["te"] — "") && ($ POST["check"] 一 1)){ 
echo "<script>alert( 内 容 不 能 为 空 );location.href='index.php'</script>"; // 输 出 提示 


}else{ 
if(lempty($_POST["check"]) || $_POST["select"] !='1){ /当下 拉 列 表 值 不 等 于 1 时 
echo "标题 : ".$_POST["text"]."<br>"; /输出 内 容 和 下 拉 列 表 内 容 
str($_POST[te].$_ POST["check"]); 
}else{ 
echo "标题 :".$_POST["text"]."<br>"; // 否 则 只 输出 文本 域内 容 
str($_ POST["te"]); 
} 
} 
b 
pe 


(2) 将 该 文件 存储 于 \MR\02\004\ 文 件 夹 下 ， 并 在 浏览 器 中 输入 http://127.0.0.1/mr/ 
02/004 浏览 文件 。 
技术 要 点 

本 实例 中 通过 自 定 义 函 数 实现 对 字符 串 中 的 空格 和 回 车 符 进行 转换 输出 ， 在 自 定义 函 
数 中 应 用 的 是 preg_replace0 函 数 ， 其 结构 如 下 : 


function str($str){ // 自 定义 函数 
$str = preg replace("/ /","&nbsp:",$str); 1/ 替换 空格 符 
$str = preg_replace("/cha(13)/","<br>",$str): /替换 回 车 符 
echo "内 容 : ".$str; // 输 出 
} 

多 学 两 招 ， 


本 例 代码 中 “$_POST["text"] 二 "||(($_POST["te"] 一 ") && ($_POST["check"] 一 1))” 
是 存在 运算 符 优先 级 的 。 为 了 避免 发 生 错误 ， 笔 者 将 先进 行 的 运算 人 为 加 上 了 小 括号 。 其 中 
$ POST["te"] 一 "可 以 用 empty($_ POST["te"]) 代 替 .。 


实例 020 日期、 时 间 的 格式 化 输出 


( 实例 位 置 : 配套 资源 \SL\02\020 视频 位 置 : 配套 资源 \SP\02\020 ) 
实例 说 明 
在 PHP 程序 设计 中 , 对 日 期 、 时间 的 格式 化 输出 是 经 常用 到 的 。 本 实例 通过 函数 date0) 
“53 


旺 示 当前 日 其. 时 间 


2011-05-11 13:53:16 


| 图 2.5 日 期 、 时 间 的 格式 化 输出 
| 实现 过 程 
| 具体 步骤 如 下 ; 


| (1) 创建 名 称 为 mdex 的 PHP 脚本 。 当 用 户 单 击 “ 显 示 当 前 日 期 、 时 间 ” 超 链接 时 ， 
| 利用 date0 函 数 根据 传 入 指定 的 参数 格式 而 实现 格式 化 输出 。 其 代码 如 下 : 


<?php 

date_default_timezone set("Asia/ShangHai"); // 设 置 时 区 

If($_GET[date] — 1){ // 通 过 get 方式 取得 参数 
cho date("Y-m-d H:i:s"); /格式 化 输出 时 间 和 日 期 

} 

?> 


| (2) 将 该 文件 存储 于 \MR\02\005 文件 夹 下 ， 并 在 浏览 器 中 输入 http://127.0.0.1/mr/ 
| 02/005 浏览 文件 。 

| 技术 要 点 

| date0 函 数 用 于 获取 系统 的 格林 威 治 时 间 。 其 语法 说 明 及 相关 参数 介绍 请 参见 实 
| 例 012。 


”多 学 两 招 : 
| 获取 当地 时 间 时 一 定 要 先 设置 时 区 ， 否 则 PHP 默认 使 用 的 是 英国 伦敦 的 零 时 区 。 而 在 我 
| 们 本 地 使 用 的 是 北京 时 间 ， 即 东 入 区 的 时 间 ， 所 以 需要 使 用 date_default timezone_set("Asia/ 
”ShangHai") 设 置 时 区 。 


实例 021 倒计时 


( 实例 位 置 配套 资源 \SL\02\021 视频 位 置 配套 资源 \SP\02\021 ) 


| 实例 说 明 


| 倒计时 功能 的 实现 ， 同 样 也 是 将 时 间 戳 做 算术 运算 。 本 实例 应 用 strtotime0 函 数 实 现 
| 倒计时 程序 ， 运 行 结果 如 图 2.6 所 示 。 


。24 。 


当前 时 间 : 2011 年 05 月 11 日 14 点 03 分 47 秒 
距 2012 年 元 旦 还 有 zss 天 


图 2.6 倒计时 


实现 过 程 
具体 步 又 如 下 : 
(1) 创建 名 称 为 index 的 PHP 脚本 文件 ， 并 设置 当前 时 区 为 中 国 上 海 。 首先， 利用 | 
time0 函 数 取得 当前 时 刻 的 时 间 改 并 保存 在 变量 中 。 然 后 ， 利 用 strtotime0 函 数 取得 2012 | 


年 1 月 1 日 的 时 间 鹤 并 保存 在 变量 中 。 最 后 ， 将 两 个 时 间 蕉 进 行 求 差 运 算 并 将 结果 转换 成 
天 数 后 输出 。 其 代码 如 下 : | 


<2php 

date_default_timezone set("Asia/ShangHai"); /设置 时 区 

echo "当前 时 间 : ".date(Y 年 m 月 d 日 也 点 1 分 s 秒 )."<br>":// 输 出 当前 日 期 

$time = timeO; /取得 当前 时 间 戳 

Stime r = strtotime("] January 2012"); /取得 指定 日 期 的 时 间 戳 | 
echo " 距 2012 年 元 旦 还 有 <b style='color:red:'>".ceil((($time r- $time)/(3600*24)))."</b> 天 ";// 输 出 | 
> 


(2) 将 该 文件 存储 于 \MR\02\006\ 文 件 夹 下 ， 并 在 浏览 器 中 输入 http://127.0.0.1/mr/ 
02/006 浏览 文件 。 | 
技术 要 点 

PHP 中 应 用 strtotime 也 数 将 任何 英文 文本 的 日 期 解析 为 UNIX 时 间 蕉 ,其 值 为 相对 于 | 
now 参数 给 出 的 时 间 , 如 果 没 有 提供 此 参数 则 用 系统 当前 时 间 , 此 时 与 实例 142 中 的 time0 | 
函数 相同 。strtotime 函数 的 语法 如 下 : | 

int strtotime ( string time [, int now] ); | 

该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如果 | 
参数 time 的 格式 是 相对 时 间 , 其 对 应 的 时 间 就 是 参数 now 来 提供 的 , 当 没 有 提供 参数 now | 
时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 失 败 ， 则 返回 false。 在 PHP5.1.0 之 前 的 版 本 中 ， | 
本 函数 在 失败 时 返回 -1。 | 


多 学 两 招 : | 
通过 上 面 几 个 实例 的 学 习 ， 读 者 应 该 明白 其 实 所 有 的 时 间 比 较 到 头 来 都 是 时 间 鹤 的 比较 ，| 
所 以 掌握 时 间 鹤 是 十 分 重要 的 。 | 


*。25 。 
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实例 022 ”中 文 图 像 验证 码 


( 实例 位 置 配套 资源 \SL\02\022 ”视频 位 置 : 配套 资源 \SP\02\022 ) 


全 A 
实例 涪 明 
| 验证 码 不 仅 可 以 使 用 数字 图 像 来 生成 ,还 可 以 使 用 中 文 图 像 来 生成 。 为 了 防止 用 户 通 
| 过 恶意 程序 登录 站 点 ， 提 高 网 站 的 安全 性 ， 在 本 实例 中 将 介绍 如 何 通过 中 文 图 像 来 生成 验 
| 证 码 ， 运 行 结果 如 图 2.7 所 示 。 


太夫 注 拖 往 理 如 录 
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图 2.7 中 文 图 像 验 证 人 码 
| 实现 过 程 

具体 步骤 如 下 ; 

(1) 创建 名 称 为 index.php 的 用 户 登录 页 面 ， 在 该 页 面 创建 表单 ， 在 表单 中 添加 用 户 
名 文本 域 、 密 码 域 、 验 证 码 文本 域 以 及 保存 随机 数 的 隐藏 域 。 

(2) 在 index.php 页 面 中 编写 PHP 脚本 ， 定 义 验证 码 所 使 用 的 中 文字 符 串 ， 并 通过 
| rand0 函 数 生成 验证 码 ， 其 关键 代码 请 参考 本 实例 的 技术 要 点 。 

(3) 本 实例 中 沿用 JavaScript 脚本 验证 技术 表单 中 元 素 进行 验证 的 方法 ，funjjs 脚本 
文件 同样 存储 于 js 文件 夹 中 。 

(4) 创建 后 台 验 证 文件 checkuserphp， 并 完成 对 用 户 提交 的 登录 信息 的 验证 。 


| 脚下 留神 : 
| 建议 在 应 用 循环 前 ， 定 义 Simg 变量 和 Spic 变量 为 空 值 ， 否 则 在 程序 运行 时 ， 系 统 可 能 会 
| 报错 。 


| 开发 中 文 图 像 验证 码 ， 首 先 应 该 确定 所 使 用 的 文字 ， 并 且 将 文字 制作 成 图 片 ， 以 数字 
| 进行 命名 。 然 后 ， 将 所 使 用 的 文字 定义 到 数组 中 。 最 后 ， 计 算出 数组 中 元 素 的 长 度 值 ， 并 
| 应 用 rand0 函 数 从 这 个 长 度 值 中 随机 取 值 ， 根 据 随机 取 值 输出 对 应 的 中 文 图 像 ， 即 验证 码 。 
| 其 关键 代码 如 下 : 


了 。26 . 


<?php 
$str = array ("大 ", "更 ", " 创 ", "天 ", " 科 ", " 客 ", " 博 ", " 技 ", " 立 ", "新 " );// 定 义 中 文字 符 串 的 数组 


$word = count ( $str ); // 计 算出 数组 中 元 素 个 数 
Sime=""; // 定 义 $img 变量 | 
Spic=""; // 定 义 $pic 变量 | 会 内 
for($i=0; $1<4; $i++) { // 执 行 for 循环 ， 以 数组 中 元 素 个 数 为 范围 随机 取出 4 个 值 一 一 
$num = rand ( 0, $word - 1 ); /Sword=-$word*2-1 // 随 机 取 值 | 
// 输 出 随机 取出 的 4 个 值 对 应 的 中 文 图 片 
Simg = $img . "<img src=' images/checkcode/" . $num . ".gif width='16' height="16>"; /显示 随机 | 
图 片 | 
Spic = $pic . $str ["$Snum"]; // 将 图 片 转换 成 数组 中 的 文字 
} 
?> 
多 学 两 招 ， 


在 本 实例 中 ， 应 用 countO 函 数 计算 数组 中 元 素 的 个 数 。 注 意 ，countO 函 数 只 适用 于 计算 | 
数组 中 元 素 的 个 数 ， 如 果 将 其 应 用 到 其 他 类 型 的 数据 中 ， 那 么 返回 值 只 有 一 个 单元 。 如 果 要 | 
计算 字符 串 的 长 度 ， 那 么 就 要 使 用 strlen0 函 数 ， 切 忌 stlen0) 函 数 不 可 对 数组 元 素 进行 操作 ， | 
虽然 不 返回 错误 信息 ， 但 是 返回 的 结果 也 是 不 准确 的 。 


实例 023 上 传 文件 到 服务 器 


( 实例 位 置 : 配套 资源 \SL\02\023 视频 位 置 配套 资源 \SP\02\023 ) 


实例 说 明 


在 开发 网 站 的 过 程 中 , 不 但 可 以 将 文件 上 传 到 数据 库 中 , 还 可 以 将 文件 上 传 到 服务 器 ，| 
这 种 方式 可 以 为 网 站 中 的 数据 库 节 省 很 多 的 空间 ， 同 时 可 以 控制 上 传 文件 的 大 小 、 格 式 ， | 
而 且 读 取 服务 器 中 的 文件 要 比 从 数据 库 中 读 取 方 便 很 多 。 运 行 本 实例 ， 如 图 2.8 所 示 ， 单 | 
击 图 中 的 “浏览 ”按钮 ， 选 择 要 上 传 的 文件 ， 然 后 单 击 “ 提 交 ” 按 钮 ， 如 果 上 传 成 功 ， 则 | 
在 页 面 中 提示 “上 传 成 功 !”， 否则 给 出 错误 提示 信息 。 | 


名 一 个 点 从 _ 的 仆人 个 


过 择 上 信 文 件 : [end_Franovork_7H. chn 多 


上 传 图 片 
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上 全线 误 上 传 文件 大 小 超 志 配置 文件 规定 什 
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图 2.8 ”上传 文件 到 服务 器 


实现 过 程 | 

创建 index.php 文件 。 首 先 添加 表单 ， 并 设置 文件 域 和 提交 按钮 。 然 后 ， 使 用 POST 

方法 设置 enctype="multipart/form-data"， 并 通过 $_FILES 获取 上 传 文件 的 相关 信息 。 最 后 ，| 
eg L_ 
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| 通过 move upload file0 函 数 完成 图 片上 传 。 其 主要 代码 如 下 : 


| <2php 
| Session start(); /开启 全 局 会 话 
| 这 !empty($_FILES["up_picture"]["name"])){ /判断 上 传 内 容 是 否 为 空 
策 - | 这 $_FILES["up_picture"]["error"]>0){ // 浏 断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错 误 :"; 
switch($_ FILES["up_picture"]["error"]){ /如 果 上 传 错误 ， 判 断 错误 原 
case ] 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 
Case 3: 
echo "上 传 文件 不 全 "; 
break:; 
Case 4: 
echo "没有 上 传 文件 "; 
break; 


} 
}else{ 
if(!is_dir("./upfile/")) { // 判 断 指 定 目 录 是 否 存在 
mkdir("./upfile/"); // 创 建 目录 


} 
$path='./upfile/time0.$_ FILES["up_picture"]["name"]; // 定 义 文件 名 称 和 存储 位 置 
if(is_uploaded_file($ FILES["up_picture"]["tmp_name"])){ /是否 是 HITP POST 上 传 
这 !move uploaded file($ FILES["up_picture"]["tmp_name"],$path)){ ”// 执 行 上 传 
echo "上 传 失 败 "; 
Jelse{ 
echo "文件 "time0.$_FILES["up_picture"]["name"]." 上 传 成 功 ， 大 小 为 : ".$_ 
FILES[up_picture]['size]; // 输 出 文件 大 小 


} 
}else{ 
echo "上 传 文件 ".$_FILES["up_pictute"]["name"]." 不 合法 ! "; 
} 
} 
| } 
| ?> 
| 技术 要 点 


| PHP 中 可 以 应 用 move_uploaded file0 函 数 实现 文件 上 传 。 在 执行 文件 上 传 之 前 ， 为 了 

| 防止 潜在 的 攻击 对 原本 不 能 通过 脚本 交互 的 文件 进行 非法 管理 ， 可 以 先 应 用 is_uploaded_ 

| file0 函 数 判 断 指定 的 文件 是 否 是 通过 HTTP POST 上 传 的 ， 如 果 是 则 返回 tue。 

| (1) is_uploaded file(0) 函 数 。 

is_uploaded fileO) 函 数 , 判断 指定 的 文件 是 否 是 通过 HTTP POST 上 传 的 。 其 语法 如 下 : 
bool is_uploaded file ( string filename ) 


。28 . 


参数 多 ename 必须 指定 类 似 于 $_FILES[Yilename][tmp_name] 的 变量 ， 不 可 以 使 用 从 ， 
客户 端 上 传 的 文件 名 $_FILES[filename'][mame']。 | 

通过 is_uploaded_file0 函 数 对 上 传 文件 进行 判断 ， 可 以 确保 恶意 的 用 户 无 法 欺骗 脚本 | 
去 访问 本 不 能 访问 的 文件 ， 如 /etc/passwd。 | 

(2) move_uploaded file(0) 函 数 。 

move_uploaded_file(0) 函 数 将 文件 上 传 到 服务 器 中 指定 的 位 置 。 如 果 成 功 则 返回 true， 

否则 返回 false。 其 语法 如 下 : 
bool move_uploaded file ( string filename, string destination ) 


参数 filename 指定 上 传 文件 的 临时 文件 名 ， 即 $_FILES[tmp_name]; 参数 destination 
指定 文件 上 传 后 保存 的 新 路 径 和 名 称 。 | 


脚下 留神 : | 
如 果 参 数 filename 不 是 合法 的 上 传 文件 ， 则 不 会 出 现任 何 操作 ,move uploaded file0 将 返 | 
回 false。 | 
如 果 参 数 flename 是 合法 的 上 传 文件 ， 但 出 于 某 些 原因 无 法 移动 ， 也 不 会 出 现任 何 操作 ， | 
Imove_ uploaded file0 将 返回 false， 此 外 还 会 发 出 一 条 警告 . | 


实例 024 读 取 整个 文本 文件 中 的 内 容 


( 实例 位 置 : 配套 资源 \SL\02\024 视频 位 置 : 配套 资源 \SP\02\024 ) 


例 说 明 


在 开发 网 站 的 过 程 中 ， 很 多 的 服务 条 款 、 协 议 等 都 是 以 文本 文件 的 形式 存储 的 。 如 果 | 
要 读 取 这 些 文件 中 的 内 容 就 需要 应 用 到 文件 系统 函数 。 也 就 是 说 , 只 有 通过 文件 系统 函数 ， | 
才能 读 取 其 中 的 内 容 。 本 实例 将 介绍 如 何 通 过 文件 系统 函数 读 取 整 个 文本 文件 中 的 内 容 ， 
运行 结果 如 图 2.9 所 示 。 
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图 2.9 读 取 文本 文件 中 的 内 容 


8 UD 


3 人 Pp 经 各 编程 265 人 


”实现 过 程 


| 具体 步骤 如 下 : 
全 | (1) 创建 index.php 文件 。 
| (2) 在 index.php 文件 中 分 别 应 用 file0 和 fie_get_contents0 函 数 读 取 文本 文件 中 的 内 
容 。 其 关键 代码 如 下 : 


<!-- ”使 用 多 e0 函 数 读 取 testl.txt 文件 的 内 容 。--> 


<?php 

$arr = file('test] .txt"); /1/ 读 取 文件 

foreach ($arr as $value) { /循环 输出 

echo iconv("gb2312", "utf-8", $value) . "<br>"; // 将 读 取 的 文字 转换 编码 格式 

} 

2 

<!-- 使 用 file _get_contentsO) 函 数 读 取 count.txt 文件 的 内 容 -> 

<?php 

$str= fle_get_contents(test2.txt): /应 用 函数 获取 文本 中 的 内 容 

echo iconv("gb2312", "utf-8", $str); // 将 读 取 的 文字 转换 编码 格式 
| pe 
| 技术 要 点 


(1) readfileO) 函 数 。 
readfile() 函 数 读 取 一 个 文件 并 写 入 到 输出 缓冲 ， 成 功 则 返回 读 取 的 字 节 数 ， 失 败 则 返 
| 回 false。 其 语法 如 下 : 
| int readfile ( string filename [, bool use_include_path [, resource context]] ) 


| 参数 flename 指定 读 取 的 文件 名 称 ; 参数 use_include_path 控 制 是 否 支 持 在 include_path 
| 中 搜索 文件 ， 如 果 支持 ， 则 将 该 值 设置 为 tue; 参数 context 是 PHP 5.0 新 增 的 内 容 。 

| (2) file0 函 数 。 

| file() 函 数 将 整个 文件 的 内 容 读 入 到 一 个 数组 中 。 成 功 则 返回 数组 ， 数 组 中 的 每 个 元 素 
| 都 是 文件 中 对 应 的 一 行 ， 包 括 换行 符 在 内 ; 失败 则 返回 false。 其 语法 如 下 : 


array file ( string filename [, int use_include_path [, resource context]] ) 


file0) 函 数 与 readfile0 函 数 相同 ， 唯 一 区 别 是 该 函数 返回 值 是 数组 。 
(3) file_get_contents0 〇 函数 。 
file_get_contents() 函 数 将 文件 内 容 读 入 一 个 字符 串 。 如 果 有 offset 和 maxlen 参数 ， 将 
| 在 参数 offset 所 指定 的 位 置 开始 读 取 长 度 为 maxlen 的 内 容 。 如 果 失 败 ， 则 返回 false。 其 语 
| 法 如 下 : 
| string file_get_contents ( string filename [, bool use_include path [, resource context [, int offset [, int 
,maxlen]ll]) 


参数 名 ename 指 定 读 取 的 文件 名 称 ; 参数 use_include_path 控 制 是 否 支 持 在 include_path 


了 。30 。 


中 搜索 文件 ， 如 果 支 持 ， 则 将 该 值 设置 为 tue。 


多 学 两 招 : 下 
在 通过 readfile0、file0 和 file get contentsO) 函 数 读 取 整 个 文件 中 的 内 容 时 ， 不 需要 通过 | 
fopen0 函 数 打 开 文 件 ， 也 不 需要 使 用 frlose() 函 数 关闭 文件 。 | 


ee 人 用 本 05 | 


件 后 才能 进行 读 取 ， 在 读 取 完 成 后 还 要 应 用 fclose0 函 数 关闭 文件 。 


实例 025 连接 MySQL 数据 库 服务 器 


( 实例 位 置 配套 资源 \SL\02\025 视频 位 置 配套 资源 \SP\02\025 ) 


实例 说 明 | 
通过 PHP 语言 连接 MySQL 数据 库 与 在 cmd 命令 提示 符 下 操作 数据 库 有 所 不 同 . 例 如 ，| 
设置 页 面 的 编码 格式 为 “GBK”。 在 MySQL 命令 提示 符 下 只 需 输 入 “set names GBK” 即 | 
可 ， 而 在 PHP 中 需 使 用 函数 “mysql_query(“set names GBK”)” 实 现 。 所 以 ， 用 户 在 学 习 | 
操作 MySQL 数据 库 的 同时 ， 还 要 与 PHP 函数 联合 应 用 。 下 面 笔者 为 用 户 讲解 PHP 操作 | 
MySQL 数据 库 的 第 一 课 。 本 实例 通过 mysgl_connect0 和 数 连接 MYSQL 数据 库 服务 器 ， 运 | 
行 结果 如 图 2.10 所 示 。 | 


连接 My SQL 服 务 论 


mr _ 天 


图 2.10 连接 MySQL 数据 库 服务 器 
实现 过 程 | 
新 建 indexphp 文件 ， 并 创建 om 表单 提交 连接 MySQL 服务 器 的 用 户 名 、 密 码 和 服 | | 


务 器 ,获取 form 表单 提交 的 数据 , 应 用 mysql_connect0 函 数 完成 与 MySQL 服务 器 的 连接 。 
其 代码 如 下 : 


<2php 
这 !empty($_POST["sub"])){ // 单 击 “ 确 定 ” 按 钮 
/检测 文本 框 是 否 有 为 空 
if (empty($_ POST["na"]) || empty($_POST["nam"] ) || empty($_ POST["name"]) ) { 
echo "<script>alert( 文 本 框 不 能 为 空 ):</script>"; /| 输出 提示 
}else{ 


。31 。 


esient flagsllll] ); 
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这 @mysql connect("$ POST[na]","$ POST[nam]","$ POST[name]")){// 连 接 MySQL 服务 器 


echo "<script>alert( 连 接 MySQL 服务 器 成 功 );</script>"; // 输 出 提示 
}else{ 
echo "<script>alert( 错 误 了 ");</script>"; 
' 
H 
} 
Ms 


mysql_connect0) 函 数 用 于 打开 一 个 到 MySQL 服务 器 的 连接 。 其 语法 如 下 : 
resource mysql_connect ( [string server [, string username [, string password [, bool new_link [, int 


参数 说 明 : 


string server: 表示 连接 数据 库 的 HOST。 
回 string usemame: 表示 连接 MySQL 数据 库 的 用 户 名 。 


| string password: 表示 连接 MySQL 数据 库 的 密码 。 


| 多 学 两 招 ， 


MySQL 数据 库 在 安装 时 会 提示 用 户 设 置 Host、 用 户 名 和 密码 。 如 果 用 户 并 未 进行 设置 ， 


| MySQL 在 默认 安装 的 情况 下 ，Host 为 “localhost*， 用 户 名 为 “root"， 密 码 为 “111"。 


实例 026 ”选择 指定 的 MySQL 数据 库 


( 实例 位 置 : 配套 资源 \SL\02\026 视频 位 置 : 配套 资源 \SP\02\026 ) 


| 实例 说 明 


通过 函数 mysql_ connectO 可 以 与 MySQL 服务 器 建立 连接 , 之 后 就 可 以 操作 数据 库 了 。 


| 在 “cmdy” 命令 提示 符 下 选择 想 要 操作 的 数据 库 需 要 使 用 “use” 语句 ， 在 PHP 代码 中 需 
| 要 使 用 函数 mysql_select_db0 选 择 并 连接 数据 库 。 本 实例 通过 函数 mysql_select_db0 实 现 与 


| MySQL 数据 库 的 选择 与 连接 ， 运 行 结果 如 图 2.11 所 示 。 


未 自 http-//1ecslhest 的 页 面 下 
企 


图 2.11 选择 指定 的 MySQL 数据 库 
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Eee 
实现 过 程 

具体 步骤 如 下 : | 
(1) 新 建 index.php 文件 。 首 先 连接 MySQL 服务 器 ， 然 后 通过 mysql 函数 库 的 本 数 | 
读 取 输出 MySQL 数据 库 中 存储 的 数据 库 名 称 , 并 且 通 过 下 拉 列 表 框 显示 所 有 数据 库 名 称 。 
其 代码 如 下 : 


<2php 
$conn = mysql_connect("localhost","root","111"); /连接 MySQL 服务 器 
S$rs = mysql_ query("show databases"); /查询 操作 
while($rst = mysql fetch array($rs)){ //while 循环 
$a=0; 
echo "<option value=".$rst[$a].">".$rst[$a]."</option><br>"; // 输 出 数据 库 名 称 
Satt; 
} 
> 


(2) 当 单 击 “ 确 定 ” 按 钮 时 ， 将 下 拉 列 表 框 的 选择 信息 以 参数 的 形式 传递 给 函 
mysql select db0， 并 输出 提示 信息 。 其 代码 如 下 : 


<2php 
if(! empty($_POST["sub"]){ // 通 过 post 方式 传递 参数 
if($_POST["select"] — "1"){ // 当 下 拉 列 表 框 值 为 1 时 
echo "<script>alert(' 请 选择 数据 库 "):</script>"; // 输 出 提示 信息 
}else{ 
if(mysql select_db("$ POST["select"]",$conn)){ // 如 果 不 为 1， 连接 数据 库 
mysql closeO:; // 关 闭 连接 
echo "<script>alert(' 已 选择 指定 数据 库 ");</script>"， /输出 提示 
}else{ 
echo "<script>alert( 出 错误 了 "):</script>"; // 提 示 信 息 
} 
} 
1 
人 
技术 要 点 


mysql_ select db 函数 用 于 选择 MySQL 数据 库 。 其 语法 如 下 : 
bool mysql_select_db ( string database_name [, resource link identifier] ); 
参数 说 明 : 


回 string database name: 表示 选择 MySQL 数据 库 的 名 称 。 
回 resource link identifier: 表示 MySQL 连接 标识 。 


多 学 两 招 : | 

本 实例 是 利用 函数 “mysql select db0” 的 返回 值 ， 判 断 是 否 连接 到 数据 库 ， 从 而 输出 提 | | 

示 信 息 。 还 可 以 通过 函数 “mysql select db() or die0” 来 判断 是 否 连接 到 数据 库 ， 如 果 连 接 到 | 

数据 库 将 不 会 有 任何 信息 提示 ， 否 则 输出 错误 信息 。 | 
二 本 本 
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实例 027 执行 SQL 语句 


( 实例 位 置 : 配套 资源 \SL\02\027 视频 位 置 配套 资源 \SP\02\027 ) 


实例 说 明 

用 PHP 代码 操作 MySQL 数据 库 的 主要 目的 是 为 了 让 程序 控制 数据 库 信 息 的 增 、 删 、 
改 、 查 等 操作 。 而 函数 mysql query0 可 以 看 作 是 部 分 SQL 语句 的 载体 。 本 实例 通过 mysql_ 
query0 函 数 执行 SQL 语句 ， 运 行 结果 如 图 2.12 所 示 。 


青 答 入 SQL 语句 ， 数 据 库 db_database02， 


SELECT » 
FROM “tb_deno019~ 
NRERE 19 = 


SELECT* 
FROM ‘to_demo0 9| 


| 
| 

| 标准 书写 格式 ， 
! WHERE id =1 


图 2.12 通过 mysql_query0 函 数 执行 SQL 语句 
大 现 过 程 
新 建 index.php 文件 。 首先， 连接 服务 器 和 db_database02 数据 库 。 然 后 ， 获 取 form 表 


单 中 提交 的 SQL 语句 ， 并 且 对 SQL 语句 的 类 型 进行 判断 ， 根 据 不 同 的 类 型 应 用 mysql_ 
query0 函 数 执行 不 同 的 操作 。 其 关键 代码 如 下 : 


if(strtoupper($sql1) =— "INSERT"){ 
if(mysql query($sql){ 


<2?php 
这 !empty($_POST["sub"])){ // 单 击 按钮 
| $sql=$_ POST[text"]; /定义 变量 
| if($sql — "){ /如 果 文本 框 为 空 
| echo "<script>alert(' 您 输入 的 文本 框 内 容 为 空 ):</script>"; //JavaScript 提示 
| jelse{ 
| $conn = mysql_connect("localhost","root","111") or die(" 连 接 MySQL 出 现 错误 /连接 MySQL 
| mysql select_db("db_database02",$conn) or die("false"); // 连 接 数据 库 
| $sqll = substr($sql,0,6):; // 截 取 SQL 语句 前 6 个 字符 
| ifstrtoupper($sql1) 一 "SELECT"){ 
| 这 mysql_ query($sqD){ /执行 查询 操作 
| echo "<script>alert(' 您 在 执行 查询 操作 ");</script>"; 
| jelse{ 
| echo "<script>alert(SQL 语句 出 现 错误 ");</script>"; 
| } 
| }else{ 
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echo "<script>alert(' 您 在 执行 插入 操作 '):</script>"; 
Jelse{ 
echo "<script>alert(SQL 语句 出 现 错误 );</script>"; 
中 
jelse{ 
这 strtoupper($sql1) =—= "UPDATE"){ 
这 mysql query($sqD)){ 
echo "<script>alert(' 您 在 更 新 查询 操作 ):</script>"; 
jelse{ 
echo "<script>alert(SQL 语句 出 现 错误 );</script>"; 


} 
} 
} 
} 
} 
} 
?> 


在 对 SQL 语句 的 类 型 进行 判断 时 ， 首 先 应 用 substr0 函数 对 SQL 语句 进 行 截取 ,截取 | 
其 前 6 个 字 节 ， 然 后 将 截取 的 内 容 转换 为 小 写 ， 并 通过 这 6 个 字符 串 对 SQL 语句 的 类 型 | 
进行 判断 。 | 
技术 要 点 | 

mysql_query0) 函 数 用 于 向 与 指定 的 连接 标识 符 关 联 的 服务 器 中 当前 活动 的 数据 库 发 
送 一 条 MySQL 查询 。 其 语法 如 下 : | 

resource mysql_query ( string query [, resource link identifier] ); 

参数 说 明 : 

回 resource link identifier: 连接 标识 。 

加 string query: SQL 语句 。 


多 学 两 招 : | 
mysql_ query0 用 于 向 与 指定 的 连接 标识 符 关联 的 服务 器 中 当前 活动 的 数据 库 发 送 一 条 查 | 
询 。 如 果 没 有 指定 link identifier， 则 使 用 上 一 个 打开 的 连接 。 如 果 没 有 打开 的 连接 ， 本 函数 会 | 
尝试 无 参数 调用 mysql connect() 函数 来 建立 一 个 连接 并 使 用 ， 其 查询 结果 会 被 缓存 。 | 


实例 028 文本 文件 分 页 读 取 
( 实例 位 置 : 配套 资源 \SL\02\028 视频 位 置 : 配套 资源 \SP\02\028 ) 
实例 说 明 


在 遍历 文件 中 的 内 容 时 ， 由 于 文件 内 容 很 大 ， 所 以 最 理想 的 方法 就 是 分 页 读 取 文 本 文 
SS 人 
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eR 
| 件 中 的 内 容 。 本 实例 中 将 介绍 如 何 通过 自 定义 函数 完成 文本 文件 中 数据 的 分 页 读 取 ， 运行 
| 结果 如 图 2.13 所 示 。 


王仁 与 了 份 龙 ! 


大 破 何 未 \ 
EE 


页 上 一 页 下 一 页 尾 页 
FozyRi ahts 四 reserved 2009 青 村 省 明日 科技 有 限 公司 


图 2.13 文本 文件 的 分 页 读 取 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 hnction php 文件 ， 并 通过 自 定义 函数 msubstr0 完 成 对 文本 文件 的 截取 操作 。 
(2) 创建 index.php 文件 。 首 先 通 过 文件 系统 函数 file_get_contents() 读 取 整 个 文件 的 
内 容 ， 然 后 调用 自 定义 函数 和 字符 串 函 数 完成 对 文件 的 截取 操作 ， 实 现 截 取 后 内 容 的 分 页 
输出 。 其 关键 代码 如 下 : 
| <div id="synopsis"> 
<!-- 创 建 div 标签 ， 用 于 获取 js 文件 中 返回 的 分 页 结果 --> 
<table width="545" border="0" cellspacing="0" cellpadding="0"> 
<tr> 

| <td><?php 
| include("finction .php"): 
| / 读 取 超 长 文本 中 的 数据 ， 实 现 超 长 文本 中 数据 的 分 页 显示 
| ifS_GET[page]){ 
S$counter=file_get_contents("data.txt"); 

Slength=strlen($counter); 

S$page_count=ceil($length/850); 

$c=msubstr($counter,0,($_GET['page']-1)*850):; 

$cl=msubstr($counter.0.$_GET[page']*850): 

echo substr($cl,strlen($c),strlen($cl)-strlen($c)); 


<td><table width="535" border="0" align="center" cellpadding="0" cellspacing="0"> 
<t> 
<!-- 设 置 超 长 文本 分 页 显示 的 超 连接 --> 
<td width="37%" align="center" valign="middle" bgcolor="#FFFFFF"> 内 
容 &nbsp;<?php echo $page_count;?> 页 &nbsp:&nbsp: 当 前 &nbsp: 第 <?php echo $ GET[page]:2> 页 </td> 
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<td width="63%" height="28" align="center"” valign="middle" bgcolor= 
"WFFFFFF"><?php 
if($ GET['page']!=1){ 
?> 


<!-- 调 用 no_refurbish _ pagination 函数 ， 实 现 无 刷新 的 分 页 输出 --> 


<a href="#" onClick='retum no_refurbish pagination("index ok.php? | 


page=1")> 首 页 </a>&nbsp; <a href="#" onClick='return no _refurbish pagination("index_ok.php?page=<?php 
echo $_GET['page']-1:?>")> 上 一 页 </a> 
<2php } 
if($ GET['page']<$page count){ 
> 

<a href="#" onClick="return no _refurbish pagination('index_ok.php?page= 
<?php echo $_ GET[page]+1;2>)"> 下 一 页 </a> <a href="#" onClick='return no refurbish pagination("index_ 
ok.php?page=<?php echo $page_count;?>")> 尾 页 </a> 


<2php 
} 
?> 
</td> 
</tr> 

</table></td> 
</tr> 
</table> 


</div> 


(3) 创建 index_ok.php 文件 ,实现 数据 的 无 刷新 分 页 。index_ok.php 中 的 内 容 与 index. 
php 中 div 标签 synopsis 的 内 容 相 同 。 
(4) 创建 js 脚本 文件 discuss jsjs， 通 过 Ajax 实现 无 刷新 的 操作 。 
完成 超 长 文本 的 分 页 输出 需要 三 方面 的 技术 : 第 一 方面 ， 自 定义 函数 。 通 过 自 定义 函 
数 读 取 文本 文件 , 可 以 避免 中 文字 符 串 出 现 乱 码 ; 第 二 方面 , 字符 串 函 数 。 需要 通过 stlen0 
函数 计算 字符 串 的 长 度 ， 通 过 substr0 函 数 对 字符 串 进行 截取 ; 第 三 方面 ， 文 件 系统 函数 。 
通过 file_get_contents() 函 数 读 取 文 本 文件 中 的 数据 。 
自 定义 函数 msubstr0 的 结构 如 下 : 


/定义 一 个 用 于 截取 一 段 字符 串 的 函数 msubstr0 
function msubstr($str,$start,$len){//$str 指 的 是 字符 串 ，$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 的 


是 长 度 

$strlen=$start+$len;// 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 

S$tmpstr= ""; /设置 变量 值 为 空 

for($i=0;$i<$strlen; $i++){ // 通 过 for 循环 语句 ， 循 环 读 取 字 符 串 
Rord(substr($str,$i,1))>0xa0){// 如 果 字 符 串 中 首 个 字 节 的 ASCII 序数 值 大 于 0xa0， 则 表示 为 汉字 
S$tmpstr.=substr($str,$1,2): // 每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 

Bitt; // 变 量 自 加 1 
}else{ // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
S$tmpstr.=substr($str,$i,1); 
} 
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retumn $tmpstr: /输出 字符 串 


国内 ”多 学 两 扫 : 


在 本 实例 中 ， 不 但 实现 了 文本 文件 内 容 的 分 页 输出 ， 而 且 是 无 刷新 分 页 输出 。 具 体操 作 
通过 js 脚本 文件 discuss jsjs 和 index okphp 文件 完成 。 


实例 029 查询 关键 字 描 红 


( 实例 位 置 : 配套 资源 \SL\02\029 视频 位 置 配套 资源 \SP\02\029 ) 


| 实例 说 明 

| 关键 字 措 红 技 术 广泛 应 用 于 站 内 搜索 或 者 高 ee Be 
| 级 搜索 中 ， 是 一 项 很 常用 的 技术 。 et 

| 数 be 实现 查询 关键 字 描 红 ， 运 行 结果 如 rg A Pn 
| 图 Se 所 示 > Ba 和 中 国 知名 网 站 新 流 ， 百 度 、 阿 里 巴巴 等 均 采 用 PHP 撤 
| 实现 过 程 图 2.14 查询 关键 字 描 红 


| 创建 PHP 脚本 文件 ， 当 单 击 “搜索 ”按钮 时 ， 首 先 通 过 post 方法 将 接收 到 的 数据 进行 
| 描 红 处 理 ， 然 后 应 用 str_replace0 函 数 对 指定 字符 串 信息 的 指定 内 容 进行 替换 。 其 代码 如 下 : 
| <2php 

if(!empty($_POST["sub"]){ 

$a = "<b style='colorred:font-size:18px:>".$_ POST["text"]."</b>"; // 对 提交 的 关键 字 进行 描 红 

| echo str_replace("$ POST["text"]",$a,$str); /完成 字符 串 的 替换 操作 
| } 
| ?> 


| 技术 要 点 


Ps 


| str_replace () 函 数 用 于 执行 字符 串 替 换 操 作 。 其 语法 如 下 : 


mixed str_replace ( mixed search, mixed replace, mixed subject [, int &count] ) 


回 ”search: 必 先 参数， 指定 需要 查找 的 字符 串 。 
回 replace: 必 选 参数 ， 指 定 替换 的 值 。 

| 回 ”subject: 必 选 参数 ， 指 定 的 查找 范围 。 
回 count: 可 选 参数 ， 获 取 执 行 替 换 的 数量 。 


多 学 两 招 : 
不 但 可 以 通过 str replace0 函 数 实现 关键 字 描 红 操 作 ， 还 可 以 通过 str ireplace0 函 数 实现 ， 
并 且 该 函数 还 不 区 分 大 小 写 . 
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实例 030 分 页 显示 图 书信 息 


( 实例 位 置 : 配套 资源 \SL\02\030 视频 位 置 : 配套 资源 \SP\02\030 ) 


select 语句 可 以 查询 数据 库 信 息 ， 但 是 如 果 数据 库 信息 非常 多 ， 在 一 个 页 面 中 显示 所 
有 数据 ， 不 仅 会 使 页 面 显得 腑 肿 、 不 美观 ， 而 且 会 给 用 户 造成 网 站 不 够 智能 的 假象 。 本 实 
例 灵活 运用 select 语句 实现 对 图 书信 息 的 分 页 处 理 ， 运 行 结果 如 图 2.15 所 示 。 


实现 过 程 


VT 
wo 书 名 价格 日 期 


6 《Cs 开发 实战 字典 》 1 元 2010-07-16 
7 《C++ 开 发 实战 宝典 》 715 无 2010-07-16 
日 《PRP 范例 宝 卖 》 i 玩 2010-07-16 
9 《YB 范例 宝 卖 》 1 无 2010-07-16 
1 《JAYA 范 位 宝 身 》 T 元 2010-07-16 


图 2.15 分 页 显示 图 书信 息 


具体 步骤 如 下 : 
(1) 创建 mphp 文件 。 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 ， 并 将 数据 库 连接 操 


作 封 装 入 类 。 


(2) 创建 index.php 文件 。 首 先 ， 包 含 数据 库 连 接 类 并 实例 化 对 象 。 其 次 ， 定 义 查 询 


语句 统计 查询 结果 集中 的 记录 数 ， 并 定义 分 页 变量 。 然 后 ， 定 义 分 页 查询 语句 ， 每 页 显示 
5 条 记录 。 最 后 ， 创 建 分 页 超 链接 ， 完 成 图 书信 息 的 分 页 显示 。 其 核心 代码 如 下 : 
<?php 
include("in.php"); // 包 含 数 据 库 连 接 类 
new mysql("localhost","root"."111","db_database02"): // 实 例 化 对 象 
这 empty($_GET["id"] ) || $_GET["id"] 一 D{ // 如 果 地 址 栏 参 数 等 于 1 
$num = 5; /定义 变量 
Srse = mysql_ query("select * from tb_demo026"); // 执 行 查询 操作 
$nu = mysql num rows($rse): // 返 回 数据 库 信 息 条 数 
if(empty($_GET["page"] )){ /设置 地 址 栏 参数 page 
Spage = 1; 
}else{ 


} 


Spage = $_GET["page"]; 


$sql = "select * from tb_demo026 limit ".(($page - 1)*$num).".".$num:// 分 页 sql 语句 


S$rs = mysql_query($sql); // 返 回 结 果 集 

Snur = ceil($nu/$num); // 取 整 函数 

echo "<a href='index .php?id=]1&page=1> 首 页 </a>"; /设置 主页 地 址 栏 参数 

这 $page >= 2){ /如 果 地 址 栏 参 数 page 值 大 于 等 于 2 
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SS 
?> 
<a href="index.php?id=1&page=<?php echo $page-1:?>"> 上 一 页 </a> ”// 上 一 页 
<?php 
} 
if($page < $nun){ // 如 果 page 小 于 总 页 数 
?> 
<a href="index.php?id=1&page=<?php echo $page+1;?>"> 下 一 页 </a> /下 一 页 
<?php 
} 
?> 
<a href="index.php?id=1&page=<?php echo $nur:?>"> 尾 页 </a> // 尾 页 
<?php 


echo "<table width='580px'><tr><td width 一 100px' bgcolor 性 FFFFF'>ID</td><td width= 
'200px> 书 名 </td><td width='180px' bgcolor= 三 FFFFF> 价 格 </td><td width='100px> 日 期 </td></tr>"; 
while($rst = mysql fetch row($rs)){ 
echo "<tr><td bgcolor=#FFFFFF'>".$rst[0]."</td><td> 《".$rst[1]."》</td><td bgcolor= 
#FFFFFF'>".$rst[2]."</td><td>".$rst[3]."</td></tr>"; 


echo "</table>"; 
} 


> 
脚下 留神 : 

其 中 让 判断 语句 内 empty($_GET["id"] )‖$_GET["idq] 一 1 的 作用 是 判断 URL 地 址 中 是 否 
存在 志 或 过 值 为 “1”。 如 果 值 判断 获取 的 记 数 为 “1”， 当 运行 程序 时 ， 可 能 会 因 无 法 获取 id 
值 而 导致 不 必要 的 错误 ， 所 以 这 里 的 判断 条 件 不 可 省 略 。 
技术 要 点 

本 实例 应 用 select 查询 语句 及 其 子 句 limit 实现 图 书信 息 的 分 页 显示 ， 通 过 limit 关键 
字 控 制 当前 页 面 显示 的 记录 数 和 开始 位 置 。 其 分 页 查询 图 书信 息 的 SQL 语句 代码 如 下 

$sql = "select * 位 om tb_demo026 limit ".(($page - 1)*$num).",".$num:; 

其 中 (($page - 1)*$num) 计 算 的 是 当前 页 的 开始 位 置 ， 而 $num 是 当前 页 显示 的 记录 数 。 
指点 迷津 : 

select 语句 中 的 limit 子 句 功能 很 强大 , 通过 它 可 以 控制 查询 语句 的 开始 位 置 ,以 及 查询 的 


数量 。 但是， 这 个 limit 子 句 是 MySQL 数据 库 特 有 的 ， 在 SQL Server 或 者 Access 数据 库 中 是 
不 支持 的 。 


多 学 两 招 : 

如 果 要 提高 网 站 的 安全 性 ， 可 以 防止 非法 用 户 进入 网 站 ， 即 在 用 户 进 入 网 站 前 进行 注册 ， 
只 有 注册 成 功 的 用 户 才 可 以 进入 网 站 。 下 面 将 通过 几 个 实例 介绍 如 何 设计 用 户 注 册 。 实 例 
031 ~ 033 向 读者 展示 了 如 何 实现 用 户 注册 的 一 般 过 程 。 
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实例 031 一 般 用 户 注册 


( 实例 位 置 : 配套 资源 \SL\02\031 视频 位 置 配套 资源 \SP\02\031 ) 


实例 说 明 


在 开发 网 络 程序 时 ， 很 多 时 候 都 会 应 一 — | 
用 到 用 户 注册 模块 。 而 用 户 注册 模块 有 简 全 
单 和 复杂 之 分 ， 本 实例 就 是 一 个 相对 比较 Es: | 
简单 的 用 户 注册 程序 。 用 户 注册 主要 就 是 sal | 
为 了 保存 用 户 的 一 些 基本 信息 ， 包 括 用 户 ee | 
名 、 真 实 姓 名 、 密 码 等 。 运 行 本 实例 ， 在 ee 
用 户 注册 页 面 中 添加 用 户 的 基本 信息 ， 填 a | 
写 完成 后 ， 单 击 “ 提 交 ” 按 钮 ， 将 用 户 注 | 
册 信 息 保存 到 数据 库 中 。 本 实例 的 运行 结 E | 
果 如 图 2.16 所 示 。 | 


图 2.16 一 般 用 户 注册 
实现 过 程 | 
具体 步骤 如 下 : 

(1) 创建 与 数据 库 的 连接 ， 代 码 如 下 : 


<?php 
S$link=mysql_connect("localhost","root","111"):; | 
mysql_select_db("db_database02",$link); | 
mysql_query("set names gb2312"); | 
> 


(2) 添加 form 表单 、 文 本 框 、 单 选 按钮 、 按 钮 ， 并 设置 相关 属性 值 。 其 关键 代码 如 下 : | 


<form action="register_deal.php" method="post" name="myform" > | 
<input name="username" type="text" id="username" size="20"> | 
<input name="truename" type="text" id="truename" size="20"> | 
<input name="pwdl" type="password" id="pwd1" size="20"> 
<input name="pwd2" type="password" id="pwd2" size="20" onBlur="javascript:if(this.value!=this. 
form.pwd1.value){ alert( 您 两 次 输入 的 密码 不 一 致 ! );}"> 
<input name="sex" type="radio" value=" 男 " checked> ! 
<input type="radio" name="sex" value=" 女 "> | 
<input name="tel" type="text" id="tel"> | 
<input name="oicq" type="text" id="oicq"> | 
<input name="email" type="text" id="email" size="28"> | 
<input name="homepage" type="text" id="homepage" size="28"> | 
<input name="address" type="text" id= "address" size="28"> 
<input name="submit" type="submit" class="btn_grey" value=" 提 交 " onClick="return checkO"> 
<input name="submit2" type="reset" class="btn_grey" value=" 重 填 "> 
</form> 
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| (3) 当 用 户 按 要 求 填写 完 注册 信息 后 ， 单 击 “ 提 交 ” 按 钮 ， 程 序 会 将 用 户 录 入 的 注 

| 册 信息 提交 到 数据 处 理 页 (register_deal.php) 进行 数据 处 理 。 首先, 载 入 数据 库 连 接 文 件 ， 

| 然后 ， 将 从 表单 中 提交 的 数据 分 别 存储 到 变量 中 ， 使 用 insert 语句 和 mysql_query0 函 数 将 
全 站 | 这 些 数据 作为 新 记录 插入 到 数据 表 中 。 其 关键 代码 如 下 : 


| <2php 
include "conmn/conn.php": // 载 入 数据 库 连接 文件 
| if($_POST["submit"]!=""){ // 判 断 提 交接 钮 


$username=$_ POST["username'"]; 

S$truename=$_POST["truename"]: 

S$pwd=$_POST["pwd1"]: 

$sex=$_POST["sex"]; 

$email=$_POST["email"]: 

Stel=$_POST["tel"]: 

$homepage=$_POST["homepage"]; 

S$oicq=$_POST["oicq"]: 

$address=$_POST["address"]; 
| $sql="insert into tb_user (username,pwd,truename,sex,email,tel,homepage,oicq,address) Values 
| (‘$username','$pwd','$truename','$sex','$email','$tel','$homepage','$oicq','$address)"; 
| $result=mysql_query($sql); /执行 添加 操作 


| if($result){ 

| echo "<script>alert( 用 户 注册 成 功 ! "):;window.location='index.php';</script>"; 
| jelse{ 

| echo "<script>alert( 用 户 注册 失败 ! ");window.location='index.php';</script>"; 
| } 

| } 

| > 

| 技术 要 点 


| 本 实例 主要 应 用 表单 提交 用 户 注册 信息 ， 应 用 insert into 语句 和 mysql_ queryO 函 数 完 
| 成 注册 信息 向 数据 表 中 添加 的 操作 。 
| mysql_query0 函 数 用 来 根据 连接 标识 符 向 数据 库 服务 器 的 当前 数据 库 发 送 查 询 。 其 语 
| 法 格式 如 下 
| int mysql_query(string query ,int [link_identifier]); 
其 中 ，query 是 查询 字符 串 ，link identifier 是 数据 库 连 接 标识 符 。 
mysql_query0 在 执行 成 功 时 返回 一 个 结果 标识 符 ， 失 败 时 返回 false。 


实例 032” 带 检测 用 户 名 的 用 户 注册 
( 实例 位 置 : 配套 资源 \SL\02\032 视频 位 置 配套 资源 \SP\02\032 ) 
| 实例 说 明 
在 开发 网 络 程序 时 ， 用 户 注册 的 形式 多 种 多 样 。 除 了 上 面 讲解 的 一 般 用 户 注册 外 ， 还 
J .42 .。 


可 以 对 相同 的 用 户 名 进行 检测 , 其 目的 在 于 检 
测 用 户 名 是 否 已 经 被 占用 。 考 虑 到 用 户 的 权限 


问题 ,一般 的 管理 网 站 不 允许 同时 存在 两 个 或 EE 
多 个 相同 的 用 户 名 , 该 方法 提高 了 网 站 的 安全 本 
性 。 运行 本 实例 ， 在 “用 户 名 ”的 文本 框 中 输 | 

入 用 户 名 ,通过 单 击 “检测 用 户 ” 超 链接 对 用 va : 
户 输入 的 新 用 户 名 进行 检测 , 从 而 判断 该 用 户 

名 是 否 已 存在 。 如 果 已 存在 , 则 提示 用 户 重新 面 面 


输入 用 户 名 ; 否则, 用 户 可 以 进行 其 他 相关 信 
息 的 输入 。 其 运行 结果 如 图 2.17 所 示 。 
实现 过 程 
具体 步骤 如 下 : 
(1) 在 注册 用 户 时 ， 一 般 不 允许 同时 存在 相同 的 用 户 名 ， 其 目的 是 为 了 便于 网 站 管 | 
理 员 区 分 不 同 的 注册 用 户 。 单 击 “ 检 测 用 户 ” 超 链接 ， 系 统 就 会 调用 JavaScript 脚本 的 | | 
openwin0 〇 函数， 将 用 户 提交 的 用 户 名 传递 到 submit checkuserphp 文件 中 ， 并 完成 对 这 个 | 
用 户 名 的 检测 操作 。 其 代码 如 下 : | 
<a href="#" onclick="javascript:openwin(myform.username.value)">[ 检 测 用 户 ]</a> 
<script language="javascript"> 
function openwin(x){ 
f(x—"){ /判断 用 户 名 是 否 为 空 
alert(" 请 输入 用 户 名 !1"); myform.username.focusO:retum false; 


}else{ /执行 用 户 名 的 检测 操作 
window.open("submit_checkuser.php?x="+x,"newframe","width=220,height=60"); 


图 2.17 带 检 测 用 户 名 的 用 户 注册 


} 
} 
</script> 


(2) 创建 submit_checkuser.php 文件 ， 通 过 $_GET 方法 获取 超 链接 传递 的 用 户 名 ， 在 
submit checkuserphp 文件 中 完成 对 用 户 名 的 检测 操作 。 其 关键 代码 如 下 : 


<2php 
header("Content-Type:text/html; charset=gb2312"); 
include "conn/conn.php"; 
$username=$_ GET['x']; 
$sql=mysql_query("select * from tb_consumer where username = '$username""); 
$result=mysql_fetch_array($sq)); 
if($result!=false){ 
echo ("[<font color=red>".$username."</font>] 已 被 注册 !"); 
}else{ 
echo (" 恭 喜 您 ! 用 户 名 [<font color=green>".$usermame."</font>] 可 以 注册 !"); 
} 
> 


(3) 创建 register_deal.php 文件 ， 获 取 表 单 提交 的 数据 ， 完 成 用 户 的 注册 操作 。 其 关 | 
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A 
键 代码 如 下 : 
<?php 
header("Content-Type:text/html; charset=gb2312"); 
include "conn/conn.php"; // 连 接 数 据 库 


if($_POST["submit"]!=""){ 
$username=$_ POST['usermame']; 
S$truename=$ POST['tmuename']; 
$pwd=$_POST['pwd1']; 
$sex=$ POST['sex']; 
$email-$ POST['email]: 
$tel=$_ POST['el]; 
$homepage=$_POST[homepage']: 
$oicq=$ POST['oicq']; 
$address=$_ POST['address']: 
$sql="insert into tb_consumer (username,pwd,truename,sex,email,tel,homepage,oicq,address) 
Values('$username','$pwd','$truename','$sex','$email','$tel','$homepage','$oicq','$address")"; 
$result=mysql_query($sql); /执行 添加 操作 
if($result){ 
echo "<script>alert( 用 户 注册 成 功 ! ");window.location='index.php';</script>"; 
jelse{ 
echo "<script>alert( 用 户 注册 失败 ! ");window.location='index.php';</script>"; 


本 实例 的 关键 是 通过 超 链接 中 的 onclick 调用 JavaScript 脚本 中 的 open 方法 打开 一 个 
窗口 ， 提 交 用 户 名 ， 在 打开 的 窗口 文件 中 完成 对 用 户 名 的 检测 操作 ， 并 且 返 回 检测 结果 。 
open 方法 可 以 打开 一 个 新 的 窗口 , 并 在 窗口 中 装载 指定 URL 地 址 的 网 页 。 其 语法 如 下 : 


WindowVar=window.open(url,windownamel[,location]); 


WindowVar: 当前 打开 窗口 的 句柄 。 如 果 open0 方 法 成 功 ， 则 WindowVar 的 值 为 一 个 
window 对 象 的 句柄 ;， 否则 ，WindowVar 的 值 是 - Ni 

url: 目标 窗口 的 URL。 如 果 URL 是 一 个 空 字 符 串 ， 则 浏览 器 将 打开 一 个 空白 窗口 ， 
允许 用 write0 方 法 创建 动态 HTML。 

windowname: window 对 象 的 名 称 。 该 名 称 可 以 作为 属性 值 在 <a> 和 <form> 标 记 的 target 
属性 中 出 现 。 如 果 指 定 的 名 称 是 一 个 已 经 存在 的 窗口 名 称 ， 则 返回 对 该 窗口 的 引用 ， 而 不 
会 再 打开 一 个 新 的 窗口 。 

location: 对 对 话 框 属性 进行 设置 的 可 选 参数 如 表 2.1 所 示 。 


表 2.1 location 属性 的 可 选 参数 值 


属 性 描述 
top | 窗口 顶部 离开 屏幕 项 部 的 像素 数 
left | 窗口 左 端 离开 屏幕 左 端的 像素 数 


width 对 话 框 的 宽度 
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对 话 框 的 高 度 


scrollbars 是 否 显示 滚动 条 
resizable 设 定 对 话 框 大 小 是 否 固 定 
toolbar 浏览 器 工具 条 ， 包 括 后 退 及 前 进 按钮 等 


menubar 菜单 条 ， 一 般 包括 有 文件 、 编 辑 及 其 他 一 些 条 上 日 
定位 区 ， 也 叫 地 址 栏 ， 是 可 以 输入 URL 的 浏览 器 文本 区 


更 新 信息 的 按钮 


location 


direction 


实例 033 ”分 步 用 户 注 册 


( 实例 位 置 : 配套 资源 \SL\02\033 视频 位 置 : 配套 资源 \SP\02\033 ) 


实例 说 明 | 

除了 上 面 讲 到 的 两 种 用 户 注 册 方 法 外 ， 用 户 注册 还 可 以 实现 分 步 注 册 的 功能 。 分 步 注 
册 可 以 让 用 户 更 清楚 地 了 解 用 户 具 有 哪些 权限 及 哪些 特殊 的 功能 。 运 行 本 实例 ， 单 击 “ 同 
意 以 上 条 款 ” 按 钮 ， 表 示 在 注册 成 为 用 户 时 ， 已 确认 该 服务 条 款 ， 此 时 将 进入 到 用 户 注册 
页 面 。 如 果 单 击 “ 不 同意 ”按钮 ， 将 不 能 进行 用 户 注册 。 进 入 用 户 注册 页 面 时 ， 按 要 求 填 
ee 填写 完成 后 ， 再 单 击 “ 提 交 ” 按 钮 ， 完 成 用 户 信息 的 注册 。 本 实例 的 

行 结果 如 图 218 和 图 2.19 所 示 。 


_ 用 户 注册 用 户 注册 
用 户 注册 协 设 用 户 名 : 
为 沪 同上 公 拓 了 序 和 社会 定语 公 目 bl 下 如 过 真实 姓名 : 
为 了 更 好 的 管理 如 堆 疡 同 站 ， 尘 纤 上 活字 以下 条 于 
一) 下 和 有 让 迪夫 商 此 天 宣传 
《 三) 二 利用 下 同 站 作 和 丰 法 人 
《三 和风 同业 上 信和 上， 性别: | 
(Ba 对 自己 的 言 哗 和 条 联系 电话 : ! 
人 Ee 2 | 
《六 可 网站 版 权 已 明日 科技 公司 不得 本 问 站 法 行 各 载 或 作 | 
为 用， ai ! 
个 人 主页 : 
家 庭 全 址 : ETESDEEF3STE3E 


DRE ES es| 要 | | 

图 2.18 用 户 注 册 协 议 图 2.19 分 步 用 户 注册 | 

实现 过 程 | 
具体 步骤 如 下 : | 


(1) 首先 确认 是 否 接 受 服务 条 款 ， 单 击 “ 同 意 以 上 条 款 ” 按 钮 将 进入 用 户 注册 页 面 ，| 
单 击 “ 不 同意 ”按钮 ， 则 不 能 进入 到 注册 页 面 。 在 index.php 文件 中 ， 输 出 注册 服务 条 款 ， | 
以 及 处 理 按钮 。 其 关键 代码 如 下 : 

<input id="Button4” style="font-size: 9pt" type=submit value=" 同 意 以 上 条 款 " name="Button1" 
‘onClick="window.location.href='register.php"> 
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| <input id="Button2"” style="font-size: 9pt” type="submit” value=" 不 同意 " name="Button2" 
| onClick="window.location .hre 全 index.php'"> 


| (2) 在 registerphp 文件 中 创建 JavaScript 脚本 , 并 通过 自 定义 方法 验证 用 户 输入 的 信 
贪 站 | 息 是 否 合法 。 其 关键 代码 如 下 : 


| <script language="javascript"> 
/判断 用 户 的 输入 是 否 合法 
| function checkO{ 
if (myform.truename.value—""){ 


alert(" 请 输入 真实 姓名 ! "):myform.truename.focus();return false; 
} 
/省 略 部 分 代码 


Var i=myform.email.value.indexOf("(@"): 

var j=myform.email.value.indexOf("."); 

这 Gi<O)llG-j>OG<O)){ 

| alert(" 您 输入 的 Email 地 址 不 正确 ， 请 重新 输入 ! ");myform.email.value="";myform.email. 
| focusOx:retum false; 


b 
myform.submitO; 
} 
</script> 
| (3) 在 register.php 文件 中 创建 “检测 用 户 ” 超 链接 , 编写 JavaScript 脚本 的 openwin() 
| 方法， 调用 submit_checkuserphp 文件 对 用 户 名 进行 检测 。 
| (4) 创建 register_deal.php 文件 ， 获 取 表 单 提 交 的 用 户 注册 信息 ， 并 应 用 insert to 语 
| 句 和 mysql_query0) 将 用 户 注册 信息 添加 到 指定 的 数据 表 中 。 
| 技术 要 点 
本 实例 在 完成 用 户 的 注册 功能 时 ， 增 加 了 一 个 服务 器 条 款 的 阅读 过 程 。 只 有 在 同意 服 
| 务 条 款 中 的 约定 之 后 ， 才 能 注册 为 本 站 的 会 员 。 
| 另外 , 在 本 实例 中 所 有 调用 JavaScript 脚本 的 操作 , 都 是 通过 鼠标 的 单 击 事件 (onclick) 
| 来 完成 的 。 
| 单 击 事件 (onclick) 是 指 在 鼠标 单 击 时 被 触发 的 事件 。 单 击 是 指 鼠 标 停留 在 对 象 上 ， 
| 按 下 鼠标 键 ， 在 没有 移动 鼠标 的 同时 放 开 鼠标 键 的 这 一 完整 过 程 。 
| 单 击 事件 一 般 应 用 于 Button 对 象 、Checkbox 对 象 、Image 对 象 、Link 对 象 、Radio 对 
| 象 、Reset 对 象 和 Submit 对 象 ，Button 对 象 一 般 只 会 用 到 onclick 事件 处 理 程序 ， 因 为 该 对 
| 象 不 能 从 用 户 那里 得 到 任何 信息 ， 如 果 没 有 onclick 事件 处 理 程序 ，Button 对 象 将 不 会 有 


| 任何 作用 。 
指点 迷津 : 
| 在 使 用 对 象 的 单 击 事件 时 ， 如 果 在 对 象 上 按 下 鼠标 键 ， 然 后 移动 鼠标 到 对 象 外 再 松 开 饼 
| 标 ， 那 么 单 击 事件 就 会 无 效 。 单 击 事件 必须 在 对 象 上 按 下 并 松 开 后 ， 才 会 执行 单 击 事件 的 处 


| 理 程序 。 
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本 章 读者 可 以 学 到 如 下 实例 : 


| 
ad 
ad 
ad 


ml 
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实例 042 
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实例 048 


员工 生日 提醒 

SWITCH 网 页 框架 

员工 信息 的 批量 删除 
do...while 语句 循环 读 取 数 据 库 中 数据 
生成 随机 验证 码 

图 形 计 数 器 
包含 数据 库 连 接 文件 

健康 生活 提醒 

这 语句 判断 美女 征婚 条 件 
网 页 版 九 九 乘 法 表 

读 取 购 物 车 中 的 数据 

多 图 片上 传 

控制 页 面 中 表情 图 的 输出 
控制 页 面 中 数据 的 输出 数量 
考试 成 绩 评定 标准 


世 
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实例 034 员工 生日 提醒 


( 实例 位 置 : 配套 资源 \SL\03\034 视频 位 置 配套 资源 \SP\03\034 ) 


| 实例 说 明 


在 PHP 应 用 中 , 类 似 生日 提醒 等 功能 的 程序 随处 可 见 , 主要 是 因为 这 样 的 程序 有 一 定 
的 定时 效果 。 本 实例 通过 站 语句 和 foreach 循环 语句 实现 一 个 员工 生日 提醒 的 小 程序 ， 运 
行 结果 如 图 3.1 所 示 。 


员工 生日 提醒 程序 


当前 日 期 : 07 月 15 日 
今天 是 小 杨 的 生日 


图 3.1 员工 生日 提醒 
实现 过 程 
具体 步骤 如 下 : 

(1) 创建 mdex.php 文件 。 首 先 ， 根 据 数组 的 特点 将 键 值 与 对 应 值 存储 在 数组 之 中 。 
然后 ， 利 用 foreach 语句 遍历 数组 ， 将 取得 的 value 值 与 当前 日 期 进行 比较 。 最 后 ， 将 符合 
条 件 的 值 进行 输出 。 其 代码 如 下 : 

<2php 
$a = array(" 小 杨 "=>"07 月 15 日 "," 小 王 "=>"07 月 28 日 "" 小 张 "=>"07 月 29 日 "" 小 李 "->"07 
月 30 日 "," 小 赵 "=>"07 月 31 日"," 小 刘 "=>"06 月 1 日 "); 
foreach($a as $key => $value){ /定义 foreach 语句 


这 date(m 月 d 日 9 一 $value){ /判断 与 当前 日 期 是 否 相同 
echo "&nbsp;&nbsp; 今 天 是 ".$key." 的 生日 "; 


} 
} 
Do 
(2) 运行 本 实例 ， 结 果 如 图 3.1 所 示 。 
技术 要 点 


本 实例 的 关键 点 是 利用 foreach 语句 循环 读 取 员工 信息 ; 利用 直选 择 语句 ， 将 文本 框 
中 的 日 期 与 数组 中 员工 日 期 进行 比较 。 
1) foreach 语句 : foreach 仅 能 用 于 数组 ， 当 试图 将 其 用 于 其 他 数据 类 型 或 者 一 个 未 
初始 化 的 变量 时 ， 会 产生 错误 。 
foreach (array_expression as $value) statement: 


参数 array 表示 要 遍历 的 数组 ,expression 表示 键 值 ,$value 表示 键 值 的 对 应 值 , statement 
表示 语句 块 。 


一 
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多 学 两 招 : | 

foreach 所 操作 的 数据 是 指定 数组 的 一 个 副本 ， 而 不 是 该 数组 本 身 。 因 此， 数组 指针 不 | 
会 被 each(0 结 构 改变 ， 对 返回 的 数组 单元 的 修改 也 不 会 影响 原 数组 。 不 过 原 数组 的 内 部 指 | 
针 在 处 理 数组 的 过 程 中 的 确 向 前 移动 了 。 假定 foreach 循环 运行 到 结束 ， 原 数组 的 内 部 指 | 
针 将 指向 数组 的 结尾 。foreach 语句 不 支持 用 “@” 来 禁止 错误 信息 。 


(2) 让 语句 : 让 语句 对 某 段 程序 的 执行 附加 一 个 条 件 ， 如 果 条 件 成 立 ， 就 执行 这 段 程 | 
序 ， 否则 ， 就 跳 过 这 上段 程序 。 | 


if(expr) statement; 


参数 expr 表示 判定 条 件 ，statement 表示 语句 块 。 
(3) array0 函 数 : 返回 根据 参数 建立 的 数组 。 参 数 可 以 用 => 运算 符 给 出 索引 。 
array array ( [mixed ...]); 


实例 035 SWITCH 网 页 框架 
( 实例 位 置 : 配套 资源 \SL\03\035 视频 位 置 配套 资源 \SP\03\035 ) 
实例 说 明 


类 似 留言 板 等 功能 较 单一 的 网 站 ， 可 以 通过 switch 语句 制作 网 页 框架 , 将 所 有 内 容 包 
含 到 主页 当中 。 本 实例 通过 switch0 语 名 和 includeO 语 句 来 演示 网 页 框架 的 制作 ， 运 行 结 | 


果 如 图 3.2 所 示 。 3 
心灵 又 
| 国 罗 这 过 
欢迎 注 遇 


单 击 包含 inc_2.php 


单 击 包含 inc.php 文件 
3 得 四 


交加 吉 ” 呈 各 


单 击 包含 inc_1.php 
文件 


图 3.2 网 页 框架 的 制作 


具体 步骤 如 下 ; | 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 switch 语句 获取 从 地 址 栏 传递 的 数据 ， 并 且 将 | 
.49 R 
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六 > 
| 数据 与 switch 语句 中 的 case 做 比较 ， 当 地 址 栏 传递 的 数据 与 case 中 的 数据 相等 时 ， 包 含 
| 指定 文件 。 然 后 ， 利 用 break 语句 跳出 switch 循环 。 其 代码 如 下 : 


| <?php 
全 站 | switch($_GET['ink ){ // 通 过 地 址 栏 接收 参数 
S| case "主页 "; /如 果 值 问 主页 
| include('inc.php’):; // 包 含 “inc.php” 文 件 
break: /结束 执行 switch 语句 
| case "注册 "; // 如 果 值 为 注册 
include(inc_1.php); 
break; 
case "浏览 ": // 如 果 值 为 浏览 
include(inc 2.php’); 
break; 
default: // 默 认 情 况 下 ， 包 含 文件 “inc.php” 
include(inc.php): 
} 
?> 
| (2) 将 该 文件 存储 于 \MR\03\035\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 3.2 
| 脚下 留神 : 


| switch 语句 在 执行 时 ， 即 使 遇 到 符合 要 求 的 case 语句 段 ， 也 会 继续 往 下 执行 ， 直 到 
| switch 语句 结束 。 为 了 避免 这 种 浪费 时 间 和 资源 的 行为 ， 一 定 要 在 每 个 case 的 语句 段 后 添 
| 如 break 跳 转 语句 跳出 当前 循环 。 


Ee 


switch 语句 和 break 语句 的 灵活 运用 是 本 实例 的 关键 。 
| (1) switch 语句 和 具有 同样 表达 式 的 一 系列 的 站 语句 相似 。 很 多 场合 下 ， 需 要 把 同 
| 一 个 变量 (或 表达 式 ) 与 很 多 不 同 的 值 比较 ， 并 根据 它 等 于 哪个 值 来 执行 不 同 的 代码 。 
switch 语句 的 语法 格式 如 下 : 
switch(variable){ 
case valuel: 
statementl: 
break: 
case Value2: 


default: 
default statement n; 
} 
| switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比较 。 如 果 不 相等 ， 则 继 
| 续 查 找 下 一 个 case; 如 果 相 等 ， 就 执行 对 应 的 语句 ， 直 到 switch 语句 结束 或 遇 到 break 为 
| 止 。 一般 switch 语句 最 终 都 有 一 个 默认 值 default, 如 果 在 前 面 的 case 中 没有 找到 相符 的 条 
| 件 ， 则 和 输出 默认 语句 ， 这 与 else 语句 类 似 。 
J 50. 
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(2) 用 break 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 


实例 036 员工 信息 的 批量 删除 


( 实例 位 置 : 配套 资源 \SL\03\036 视频 位 置 配套 资源 \SP\03\036 ) 


实例 说 明 


在 操作 数据 库 的 过 程 中 ， 可 能 会 出 现 很 多 无 用 的 元 余 
信息 。 想 要 删除 它们 , 用 户 可 以 使 用 while 循环 语句 循环 删 7 
本 实例 通过 while 循环 语句 实现 员工 信息 的 批量 删除 ， 姓名 为 郭靖 的 员工 已 被 员 除 

行 结果 如 图 3.3 所 示 。 


人 现 过 程 

具体 步骤 如 下 : 

(1) 创建 PHP 脚本 文件 。 首 先 ， 连 接 MySQL 数据 库 服务 器 ， 选 择 MySQL 中 名 称 | 
为 db_while 的 数据 库 ， 并 设置 页 面 的 编码 格式 。 然 后 ， 定 义 循环 变量 Sa 和 $b， 青 将 第 一 


层 while 循环 中 的 循环 条 件 设置 为 9b<$a。 最 后 ， 再 次 利用 while 语句 循环 输出 数据 表 中 的 
数据 ， 并 执行 数据 的 删除 操作 。 其 代码 如 下 : | 


图 3.3 员工 信息 的 批量 删除 


<2?php 
ifisset($_POST['sub])){ // 通 过 POST 方式 获取 参数 
$conn = mysql_connect("localhost","root","111"); // 连 接 mysql 数据 库 
mysql_select_db("db_database03",$conn): // 连 接 数 据 库 
mysql_query("SET NAMES utf8"): // 定 义 编码 格式 
$a =$_POSTh'te']; // 接 收文 本 框 参 数 
$b=0; /定义 变量 
while($b < $a){ //while 循环 
S$rs = mysql_ query("select * from tb_while"): // 执 行 查询 操作 
while($rst = mysql_fetch_array($rs)){ // 将 查询 结果 保存 在 数组 中 
$sql = "delete from tb_while where id = $b"; /sql 语句 
mysql_query($sqD; 1/ 执行 删除 操作 
echo "姓名 为 ".$rst[mame']." 的 员工 已 被 删除 <br>"; /输出 被 删除 的 员工 姓名 
$b++; 
} 
} 
} 
?> 


(2) 将 该 文件 存储 于 \MR\03\036 文件 夹 下 ， 并 命名 为 ndex.php。 运 行 结 果 如 图 3.3 所 示 。 
技术 要 点 | 


本 实例 的 关键 点 是 while0 循 环 语句 的 灵活 运用 。 根据 提 交 的 参数 值 , 执行 while0 任 环 | 
语句 ， 在 循环 体 中 执行 删除 操作 ， 完 成 数据 的 循环 删除 操作 。 | 
while0 循 环 语句 , 其 作用 是 反复 地 执行 某 一 项 操作 , 是 循环 控制 语句 中 最 简单 的 一 个 ， | 
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也 是 最 常用 的 一 个 。while0 循 环 语句 对 表达 式 的 
值 进行 判断 ， 当 表达 式 为 非 0 值 时 ， 执行 while0 
语句 中 的 内 柑 语 句 ， 当 表达 式 的 值 为 0 值 时 ， 则 
不 执行 while0 语 句 中 的 内 风 语 句 。 该 语句 的 特点 
是 : 先 判 断 表 达 式 ， 后 执行 语句 。while0 循 环 控 
制 语 句 的 操作 流程 如 图 3.4 所 示 。 


其 语法 如 下 : 图 3.4 while0 循 环 控制 语句 的 操作 流程 
while (expn){ 放 
statement; 先 判断 条 件 ， 当 条 件 满足 时 执行 语句 块 否则 
不 向 下 执行 
} 过 


只 要 while 表达 式 expr 的 值 为 tue， 就 重复 执行 嵌 套 中 的 statement 语句 ， 如 果 while 


| 表达 式 的 值 一 开始 就 是 false， 则 循环 语句 一 次 也 不 执行。 


实例 037 do...while 语句 循环 读 取 数 据 库 中 数据 


( 实例 位 置 : 配套 资源 \SL\03\037 视频 位 置 配套 资源 \SP\03\037) 


实例 说 明 


| 行 结果 如 图 3.5 所 示 。 


| 实现 过 程 


本 实例 通过 do...while 循环 语句 循环 读 取 数据 库 中 的 数据 ， 并 输出 员工 详细 信息 ， 运 


旺 加 ， ”年 区 ?出生 日期， 所 在 地 十， GQ 
隆 名 ,阳光 年 瞧 ，25 ”出 生日 期 ，1986-06-06* 所 在 地 址 ， 吉 林 省 长 春 市 ”aQiw 284126974| 


| 姓名， 郭 清 ”年 岭 ，25 “出 生日 期 下 0000-0030Y 所 在 地 址 ， 宋 代 江 梁 ”6Q，x 芒 x 到 站 


姓名， 黄 其 年龄, -25 “出 生日 期 ，0000-00-00_ 所 在 地 址 ， 宁 从 省 梁 6Q，xxxxxxkix 


图 3.5 员工 详细 信息 浏览 


具体 步骤 如 下 : 

(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 mysql _connect 函数 连接 MySQL 数据 库 ， 利 用 
Imysql_ select db 函数 选择 数据 库 ， 并 通过 mysql_ query 函数 定义 页 面 的 编码 格式 。 然 后 ， 
定义 SQL 查询 语句 并 返回 结果 集 。 最 后 ， 通 过 do...while 语句 循环 输出 数据 库 中 的 数据 。 
其 代码 如 下 : 


<?php 
$conn = mysql_ connect("localhost","root"."1117) /连接 数据 库 服务 器 
mysql select_db("db_database03",$conn): // 连 接 数 据 库 
mysql query("SET NAMES GBK"): // 设 置 编 码 格式 
$rs = mysql query("select * from tb_while"): // 执 行 查询 
do{ 
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echo "姓名 : ".iconv('gbk',"tf-8",$rst[1])."&nbsp;&nbsp: 年 龄 : "iconv('gbk',"utf-8',$rst[2])."&nbsp:; 
&nbsp; 出 生日 期 : "iconv('gbk',"utf-8',$rst[3])."&nbsp;&nbsp; 所 在 地 址 : "iconv('gbk',utf-8,Srst[4])."&nbsp; | 
&nbsp;QQ: "iconv('gbk',"utf-8",$rst[5])."<br><br>"; | 
}while($rst = mysql fetch array($rs)); 


| 和合- 
(2) 将 该 文件 存储 于 \MR\03\037\ 文 件 夹 下 ， 并 命名 为 index .php。 运 行 结果 如 图 3.5 
有 


脚下 留神 : 
在 使 用 do...while 语句 之 前 ， 要 事先 考虑 程序 是 否 有 必要 在 判断 条 件 之 前 运行 一 次 。 
如 果 没 必要 ， 就 尽量 不 要 使 用 ; 否则 ， 可 能 会 出 现 意外 的 输出 结果 。 


技术 要 点 


while 语句 还 有 另外 一 种 表示 形式 一 一 do...while。do...while 循环 语句 和 while 循环 语 | 

句 非常 类 似 ， 只 是 do...while 循环 语句 是 在 循环 底部 检测 循环 表达 式 ， 而 不 是 在 循环 的 项 | 

部 进行 检测 。do...while 循环 语句 的 语法 格式 如 下 : | 
dof 

statment 

}while(exp?); | 

该 语句 的 操作 流程 是 ， 先 执行 一 次 指定 的 循环 体 语句 ， 然 后 判断 表达 式 的 值 。 当 表达 | 

式 的 值 为 非 0 时， 返回 重新 执行 循环 体 语句 。 如 此 反复 ， 直 到 表达 式 的 值 等 于 0 为止， 此 | 

时 循环 结束 。 其 特点 是 先 执 行 循 环 体 ， 然 后 判断 循环 条 件 是 否 成 立 。do...while 循环 语句 | 

的 操作 流程 如 图 3.6 所 示 。 | 


> 循环 体 语句 
9 当 表 达 式 值 为 真 
(a) (b) 


图 3.6 do...while 循环 语句 的 操作 流程 


实例 038 ”生成 随机 验证 码 


( 实例 位 置 : 配套 资源 \SL\03\038 视频 位 置 配套 资源 \SP\03\038 ) 


实例 说 明 | 

在 用 户 登录 页 面 或 留言 发 表 页 面 经 常会 看 到 验证 码 的 身影 通过 这 项 技术 可 以 很 大 程 | 

度 地 提高 网 站 的 安全 性 。 运 行 本 实例 ， 可 以 发 现在 如 图 3.7 所 示 的 登录 页 面 中 随机 产生 了 | 

4 位 数字 (6191)。 每 次 刷新 页 面 ， 这 4 位 数字 都 在 发 生 改变 。 用 户 登录 时 要 求 输入 这 4 位 | 
i UD 


| 
| 
| 

全 办 | EE 下 
! 

~ 和 ~ | 


| 3 
0 
:En 人 
| 
| 
| 
| 


| 图 3.7 生成 随机 验证 码 
| 实现 过 程 
| 具体 步骤 如 下 


(1) 创建 用 户 登 录 页 面 ， 添 加 用 户 登 录 表 单 。 
(2) 创建 JavaScript 脚本 ， 定 义 chkuserinput( 方 法 对 表单 中 提交 的 数据 进行 验证 。 


<script language="javascript"> 
function chkuserinput(form){ 
if(form.usemame.value—""){ 
alert(" 请 输入 用 户 名 !"); 
form.username.selectO: 
Tetum(false); 
} 
if(form.userpwd.value—"") { 
alert(" 请 输入 用 户 密码 1"); 
form.userpwd.select(O; 
return(false); 
} 
if(form.yz.value—""){ 
alert(" 请 输入 验证 码 !"); 
form.yz.selectO: 
return(false); 
} 
return(true); 
上 
</script> 


(3) 编写 PHP 脚本 ， 通 过 mt_rand0 函 数 生成 4 位 随机 验证 码 ， 并 输出 4 位 随机 验证 


| 码 对 应 的 图 片 。 运 行 结果 如 图 3.7 所 示 。 
| 技术 要 点 


应 用 PHP 的 随机 函数 mt rand0 生 成 随机 验证 码 ， 并 根据 随机 验证 码 的 值 读 取 对 应 的 


| 数字 图 片 生成 验证 码 图 像 。 
mt_rand() 函 数 用 于 产生 min 和 max 之 间 的 随机 数 。 其 语法 如 下 : 


int mt_rand([int min].[int max]) 


区 。54 。 
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参数 min 和 max 指定 随机 数 的 取 值 范 围 。 
在 读 取 生成 的 随机 验证 码 时 ， 应 用 到 for 语句 和 substr0 函 数 对 验证 码 的 值 进 行 读 取 ， 
并 根据 读 取 的 值 定义 输出 的 数字 图 像 。 其 关键 代码 如 下 : 


<2php 
$num = intval (mt rand ( 1000, 9999 ) ); /生成 随机 验证 码 
for($i=0; $i1<4; $1+1+) { /循环 读 取 验 证 码 
echo "<img src=images/code/" . substr ( strval ( $num ), $i, 1 ) .".gif>";// 输 出 数字 图 像 
上 
2 


实例 039 ”图形 计数 器 


( 实例 位 置 : 配套 资源 \SL\03\039 视频 位 置 : 配套 资源 \SP\03\039 ) 


实例 说 明 
网 站 计数 器 的 形式 有 很 多 ， 图 形 
计数 器 是 比较 常用 的 一 种 。PHP 制作 
图 形 计 数 器 的 方法 主要 有 两 种 : 一 种 
可 以 利用 GD2 函数 直接 绘制 图 形 , 另 
eg 会 制 工具 将 图 
形 绘制 出 来 , 然后 用 PHP 代码 进行 调 
用 。 本 实例 将 采用 第 二 种 方式 来 实现 
统计 网 页 的 访问 量 ,运行 结果 如 图 3.8 
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所 示 。 图 3.8 图 形 计数 器 
现 过 程 
具体 步骤 如 下 : 


(1) 创建 index.php 文件 ， 设 计 网 站 的 页 面 ， 输 出 公司 简介 的 内 容 。 | 
(2) 在 index.php 文件 中 ， 通 过 文件 系统 函数 编写 一 个 文本 计数 器 ， 将 数据 存储 于 文 | 
本 文件 countertxt 中 ， 并 通过 SESSION 变量 屏蔽 页 面 的 刷新 。 其 关键 代码 如 下 : 


<2php | 
session start (): | 
寺 ($_SESSION [temp] 一 "") { /判断 $_SESSION[temp] 一 "的 值 是 否 为 空 ,其 中 的 temp 为 自 定义 | 
的 变量 | 
if(($fp = fopen ("counter.txt", "r" )) 一 false) { 
echo "打开 文件 失败 1"; 


}else { 
$counter = fgets ( $fh, 1024 ); // 读 取 文件 中 数据 
felose ( $fp ): // 关 闭 文本 文件 
$counter ++: 1/ 计数 器 增加 1 
$fp =fopen ( "counter txt", "w" ): // 以 写 的 方式 打开 文本 文件 
fputs ( $fp, $counter ): // 将 新 的 统计 数据 增加 1 


SS L_ 
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pr 
x 
% 
felose ( $fp ): /关闭 文件 
} 
$_SESSION [temp]= 1; /为 $ SESSION[temp] 赋 一 个 值 


?> 


(3) 在 index.php 文件 中 ， 通 过 文件 系统 函数 读 取 文本 文件 中 存储 的 网 站 访问 量 的 数 


Note | 据 ， 并 将 数据 以 图 形 的 形式 输出 。 相 关 代 码 请 参考 技术 要 点 中 的 内 容 。 


| 多 学 两 招 ; 


第 二 种 将 数字 转换 成 图 形 的 方法 如 下 : 
首先 ， 应 用 函数 intval0 将 计数 器 的 值 转变 成 字符 串 。 然 后 设置 计数 器 最 多 显示 8 位 数 


字 (当然 位 数 可 以 根据 实际 情况 设 定 )， 并 根据 stlen0 函 数 确 定 当前 计数 值 的 位 数 ， 再 用 
| 8 减 去 该 位 数值 ， 得 出 剩余 的 位 数 ( 为 了 使 页 面 美观 ， 剩 余 的 位 数值 用 0 填充 )。 最 后 输出 
| 文本 文件 中 统计 的 数据 。 其 关键 代码 如 下 : 


S$imagenum=intval($num): // 类 型 转换 
for($i=0;$1<8-strlen($imagenum); $i++){ 
echo "<img src=images/count/0.gif>"; // 用 0 填充 剩余 的 位 数 
} 
for($i=0;$i<strlen($imagenum);$i++){ // 通 过 循环 调用 图 片 显示 结果 
echo "<img src=images/count/".substr($imagenum,$1,1).".gif>"; 
| 
| 技术 要 点 


图 形 计数 器 设计 原理 如 下 : 
(1) 为 了 避免 用 户 通 过 刷新 页 面 来 提高 网 站 的 访问 量 ， 可 以 通过 SESSION 变量 进行 


屏蔽 。 首 先 ， 通 过 判断 $_SESSION [temp] 的 值 是 否 为 空 决定 计数 器 的 值 是 否 加 1， 如 果 该 
| 值 不 为 室 ， 说 明 用 户 正 在 访问 该 网 站 ， 这 时 计数 器 的 值 不 加 1， 反 之 加 1。 


(2) 将 文本 文件 中 存储 的 访问 量 数据 以 数字 图 片 的 形式 输出 。 首 先 ， 应 用 strlen0) 函 


| 数 获 取 文本 文件 中 数据 的 长 度 。 然 后 ， 定 义 网 站 访问 量 的 最 大 值 为 6 位 数字 《当然 位 数 可 
| 以 根据 实际 情况 设 定 )， 用 0 填充 剩余 位 数 。 最 后 ， 通 过 for 循环 和 switch 语句 ,将 从 文本 
| 文件 中 读 取 的 数据 以 图 形 的 形式 输出 ， 其 关键 代码 如 下 : 


Slen = strlen ( $counter ): // 获 取 字 符 串 的 长 度 
$str = str_repeat ( "0", 6 - $len ): // 获 取 6-$len 个 数字 0 
for($i= 0; $i< strlen ( $str ): Si+0) { // 获 取 变 量 $str 的 字符 串 长 度 


Sresult = $str [$1]; 
$result = '<img src=images/0.gif>"; 
echo $result: 1/ 循环 输出 $result 的 结果 


} 
for($i= 0: $i < strlen ( $counter ); $i ++) { // 获 取 字 符 串 的 长 度 
$result = $counter [$1]:; 
switch ($result) { 
// 如 果 值 为 "0", 则 输出 0.g 站 图 片 


case "0": 


*。56 。 
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Sret [$i] = "0.gif"; 


break; 
Case "l= 
Sret [$i] = "1.gif'; 
break: 
[Case 2 
Sret [$i] = "2.gif': 
break;: 
/省 略 部 分 代码 | 
} | 
echo "<img src=images/" . $ret [$i] . ".>"; // 输 出 文本 文件 中 存储 的 数据 | 
) 
实例 040 包含 数据 库 连 接 文件 
(实例 位 置 : 配套 资源 \SL\03\040 视频 位 置 : 配套 资源 \SP\03\040 ) | 
实例 说 明 
一 个 程序 可 能 要 与 数据 库 多 次 交互 , 所 以 数据 库 连 接 信 
息 要 单独 保存 在 一 个 文件 中 ， 这 也 是 代码 重用 的 一 种 体现 。 后 | 
本 实例 通过 include0 语 名 包含 数 据 库 连 接 文件 ,运行 结果 如 ey Ni 
图 3.9 所 示 。 入 8 巡 " 刘 所 和 


实现 过 程 


图 3.9 包含 数据 库 连接 文件 


具体 步 又 如 下 : 
(1) 创建 index.php 文件 ， 通 过 include0O 语 句 包含 数据 库 文件 ， 并 执行 查询 操作 ， 输 
出 结果 。 其 代码 如 下 : 


<?php 
include ("inc.php"): // 包 含 数据 库 连接 文件 | 
$sql = "select * from tb_include": /sql 语句 
$rs = mysql_query($sq)):; /执行 查询 操作 | 
while($rst = mysqL_fetch_array(Srs)){ // 将 查询 结果 循环 输出 | 
echo ' 编 号 : '.$rst[0].&nbsp:&nbsp: 姓 名 : '.$rst[1]."<br>"; | 
} | 
?> | 
(2) 创建 数据 库 连 接 文件 mcphp。 其 代码 如 下 : | 
<php | 
$conn = mysql_connect("localhost","root","111"); // 连 接 MySQL | 
mysql select_db("db_database03",$conn): // 连 接 数 据 库 | 
mysql query("SET NAMES GBK"): // 设 置 编码 格式 | 
J | 
技术 要 点 


includeO 语 名 与 require0O 语 句 在 作用 上 是 完全 相同 的 ， 但 在 使 用 include 语句 引用 外 部 
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文件 时 ， 只 有 代码 执行 到 include 语句 ， 才 将 外 部 文件 引用 进来 并 读 取 文 件 的 内 容 ， 当 所 
| 引用 的 外 部 文件 发 生 错误 时 , 系统 只 给 出 一 个 警告 ,整个 PHP 文件 则 继续 向 下 执行 include 
| 语句 的 语法 如 下 : 

全 内 | void include(string filename);: 


5。 fename， 指定 的 完整 路 径 文 件 名 。 


实例 041 健康 生活 提醒 


( 实例 位 置 : 配套 资源 \SL\03\041 视频 位 置 配套 资源 \SP\03\041 ) 


| 实例 说 明 
| 一 些 手机 在 开机 时 会 出 现 开机 问候 语 或 者 提示 今日 
| 日 程 。 本 实例 就 是 类 似 这 样 的 程序 ， 通 过 switch0 语 句 根 


| 据 当前 日 期 给 出 健康 生活 提示 信息 ， 运 行 结果 如 图 3.10 辣 
| 所 示 。 


| 实现 过 程 
| 具体 步骤 如 下 ; 
(1) 创建 PHP 脚本 文件 。 首先, 通过 date 函数 取得 当前 是 星期 几 。 然后, 利用 switch 
| 语句 进行 操作 ， 并 通过 echo 语句 输出 信息 提示 。 其 代码 如 下 


<2php 

$a = date("]"); // 取 得 当前 是 星期 几 

switch($a){ 
case "Monday": // 当 前 如 果 是 星期 一 
echo "今天 是 星期 一 ， 一 周 忙碌 生活 开始 了 "; /输出 
break; 
case "Tuesday"; // 当 前 如 果 是 星期 二 
echo "今天 是 星期 二 ， 电 视 台 下 午 两 点 以 后 部 分 休息 ";// 输 出 
break; 
case "Wednesday"; // 当 前 如 果 是 星期 三 
echo "今天 是 星期 三 ， 下 午 有 乒乓 球 比赛 "; // 输 出 
break; 
case "Thursday": // 当 前 如 果 是 星期 四 
echo "今天 是 星期 四 ， 晚 上 有 NBA 的 重播 "; // 输 出 
break: 
case "Friday"; // 当 前 如 果 是 星期 五 
echo "今天 是 黑色 星期 五 ……"; /| 输出 
break; 
case "Saturday": // 当 前 如 果 是 星期 六 
echo "今天 是 星期 六 ， 明 天 就 放假 了 哈哈 哈 ": // 输 出 
break; 
case "Sunday": // 当 前 如 果 是 星期 日 
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echo "今天 是 星期 天 ， 可 以 玩 上 一 整 天 "; /| 输出 
上 
> | 
(2) 将 该 文件 存储 于 \MR\03\041\ 文 件 夹 下 ， 并 命名 为 mdexphp。 运 行 结果 如 图 3.10 | 
所 示 。 | 


指点 迷津 : | 
switch0 语 名 与 让..else... 语 句 在 功能 上 基本 相同 ， 只 是 switch() 语 句 更 加 灵活 ， 格 式 更 | 
加 鲜明 ， 结 构 更 加 清晰 。 


技术 要 点 


本 实例 的 关键 点 是 利用 switch 语句 ， 将 地 址 栏 传递 的 数据 与 switch 中 case 值 进行 比 
较 ， 符 合 条 件 的 利用 echo 语句 输出 对 应 数据 。 | 
虽然 elseif 语 句 可 以 进行 多 重 选择 ， 但 使 用 上 十 分 烦琐 。 为 了 避免 过 语句 的 见长 ,， 提 | 
高 程序 的 可 读 性 ， 可 以 使 用 switch 分 支 控 制 语句 。switch 语句 的 语法 格式 如 下 : | 
switch(variable){ 
case valuel: 
statement]; 
break: 
case Value2: 


default: 
defulat statement: 


} 


switch 语句 根据 variable 的 值 ， 依 次 与 case 中 的 value 值 相 比 较 。 如 果 不 相 等 ， 则 继 | 
续 查找 下 一 个 case; 如 果 相 等 ， 就 执行 对 应 的 语句 ， 直 到 switch 语句 结束 或 遇 到 break 为 | 
止 。 一般 switch 语句 最 终 都 有 一 个 默认 值 default, 如 果 在 前 面 的 case 中 没有 找到 相符 的 条 | 
件 ， 则 输出 默认 语句 ， 这 与 else 语句 类 似 。 | 
switch 语句 的 流程 控制 如 图 3.11 所 示 。 


3.11 ”switch 语句 流程 控制 图 | 
.59 . L_ 
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实例 042 让 语句 判断 美女 征婚 条 件 


( 实例 位 置 : 配套 资源 \SL\03\042 视频 位 置 配套 资源 \SP\03\042 ) 


a 
实例 说 明 


条 件 语 句 的 应 用 ， 小 到 一 个 简单 的 判断 登录 用 户 权限 的 模块 ， 大 到 高 负载 、 高 访问 量 
的 大 型 网 站 的 整个 程序 中 都 会 有 它 的 身影 .如 何 熟练 地 掌握 站 条 件 语句 的 应 用 呢 ? 其 实 很 简 
单 , 每 个 应 用 语句 都 有 其 特点 和 使 用 原则 , 特别 是 在 多 层 嵌 套 的 让 语句 中 , 它 的 应 用 原则 是 : 
无 论 多 少 层 语 句 的 撕 套 ， 只 要 找到 让 语句 开始 处 和 闭合 处 ， 一 般 就 不 会 产生 逻辑 错误 。 

本 实例 来 源 于 网 络 上 的 一 个 笑话 ， 其 主要 内 容 为 : 一 女子 让 计算 机 为 其 征婚 ， 开 出 征 
婚 条 件 有 两 点 : @ 要 帅 ;，@ 要 有 车 。 计 算 机 为 她 搜寻 到 了 结果 并 回答 她 说 ; 女士 您 搜寻 
的 是 象棋 吗 ? 这 位 女子 不 愿 接受 此 次 搜寻 的 结果 又 重新 输入 条 件 : @ 要 有 很 多 钱 ， @ 要 
有 漂亮 的 房子 。 计 算 机 为 她 再 次 搜寻 了 结果 : 女士 ， 您 搜寻 的 是 银行 吗 ? 此 女子 仍然 不 失 
望 ， 继 续 输 入 条 件 : @ 要 有 安全 感 ，@ 要 长 得 酷 。 结 果 计 算 机 搜 出 的 是 ， 女士， 您 搜寻 
的 是 奥 特 曼 吗 ?此 女子 想 尝试 最 后 一 次 ， 于 是 输入 条 件 : 四 要 有 很 多 钱 、 要 长 得 酷 、 要 
有 安全 感 ，@ 有 车 、 要 帅 、 要 有 漂亮 的 房子 。 计 算 机 搜寻 了 很 久 才 回答 道 ， 哦 ， 女 士 ， 
我 知道 了 ， 您 搜寻 的 是 奥 特 曼 在 银行 里 下 象棋 。 程 序 的 运行 结果 如 图 3.12 所 示 。 


! 一 女子 让 计算 机 岳 他 搜寻 结 | 条件 
| 果 ， 开 出 征婚 条 件 有 两 点 /| 
Teammmae 一 一 区 六 


此 女子 仍然 不 失望 ， 还 继续 
输入 条 件 : 
一 -一 、 
要 有 岂 色 伟 ， 要 再 杉 ， 要 有 安全 下 | 。 条件 四 
站， 要 仙 ， 要 有 用 严 的 内 了 \ J 
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图 3.12 站 语句 判断 美女 征婚 条 件 

| 实现 过 程 

| 具体 步骤 如 下 : 

| (1) 自 定义 函数 , 通过 定义 页 面 的 布局 , 动态 地 向 页 面 中 插入 文本 和 提交 按钮 的 value 
| 属性 值 。 其 具体 方法 是 ， 首 先 定义 两 个 <div> 标 签 ， 在 内 层 的 <div> 标 签 中 定义 <p> 标 签 ， 
| 利用 插入 PHP 代码 的 形式 动态 接收 自 定义 函数 首部 $str 参数 。 提 交 按 钮 <inpu 人 标签 中 , 在 
| value 属性 值 的 位 置 也 使 用 同样 的 方法 接收 参数 。 其 具体 代码 如 下 : 


<2php 
function if isset($str,$str1){ 
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> 
<div class="one"> 
<div id="one"> 
<p><?php echo $str;?></p> 
<form action=""method="post"> 
<input type="text" name="text1"size="40" value=" 要 帅 " > 
<input type="text" name="text" size="40" value=" 有 车 "> 
<input class="two" type="submit" name="<?php echo $str1?>" value=""> 
</form> | 
</div> | 
</div> | 
<2php | 


} 
这 lisset($_POST['sub])&&lisset($_POST['subl])&&lisset($_POST[sub2])){ | 
让 isset(" 一 女子 让 计算 机 帮 她 搜寻 结果 ， 开 出 征婚 条 件 有 两 点 :","sub"); 
} 
ifisset($_POST['sub])){ 
if isset(" 这 位 女子 ， 不 服 搜 出 的 结果 又 输入 :","sub1"); 
} 
if(isset($_POST['sub1'D)){ 
站 isset(" 此 女子 仍然 不 失望 ， 继 续 输入 条 件 :","sub2"); 
lj 
ifisset($_POST['sub2])){ 
让 isset(" 此 女子 仍然 不 失望 ， 还 继续 输入 条 件 :","sub3"); 
} 
(2) 利用 直 ..else 语句 和 if...elseif 语句 榜 套 的 形式 ， 根 据 接收 文本 框 参数 的 不 同 ， 
输出 对 应 的 页 面 信息 。 其 代码 如 下 : 
iftisset($_ POST['sub'])llisset($_POST['sub1"'])llisset($_POST['sub2'])llisset($_POST['sub3"])){ 
if($_POST['text]=" 有 车 "&&$_POST['text1'] 一 "要 帅 "){ 
echo "<script>alert( 计 算 机 得 出 结果 : 女士， 您 搜寻 的 是 象棋 吗 ? ')</script>"; | 
}elseif($_POST['text] 一 "要 有 漂亮 的 房子 "&&$_POST['text1'"] 一 "要 有 很 多 钱 "){ | 
echo "<script>alert( 计 算 机 得 出 结果 : 女士 ， 您 搜寻 的 是 银行 吗 ? ')</script>"; | 
}elseif($_POST['text] 一 "要 长 得 酷 "&&$_POST['text1'] 一 "要 有 安全 感 "){ 
echo "<script>alert( 计 算 机 得 出 结果 : 女士 ， 您 搜寻 的 是 奥 特 曼 吗 ? ')</script>"; | 
jelseifS_ POST[Yext]--" 有 车 , 要 帅 , 要 有 漂亮 的 房子 0&&S_POST[textl] 一 "要 有 很 多 钱 ， | 
要 长 得 酷 ， 要 有 安全 感 "){ | 
echo "<script>alert( 计 算 机 得 出 结果 : 哦 ， 女 士 ， 我 知道 了 ， 您 搜寻 的 是 奥 特 曼 在 银 | 
行 里 下 象棋 ');location.href='index.php'</script>"; | 
jelse{ 
echo "<script>alert(' 输 入 信息 错误 );</script>"; | 
} | 
} | 


> 1 
技术 要 点 


本 实例 主要 应 用 条 件 判断 语句 if...else 语句 和 if...elseif 语 句 。 
大 多 数 时 候 ， 总 是 需要 在 满足 某 个 条 件 时 执行 一 条 语句 ， 而 在 不 满足 该 条 件 时 执行 其 
直到 
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| 他 语句 。 这 时 ， 可 以 使 用 else 语句 ， 其 语法 格式 为 : 
| iflexpd){ 


| statement]: 
# | Jelse{ 
食 和 一 | statement2; 


} 
Note 
2 该 语句 的 意思 为 : 当 表达 式 expr 为 真 时 ， 执 行 statement1; 如 果 表 达 式 expr 为 假 ， 则 
| 执行 statement2。 让 语句 的 流程 图 如 图 3.13 所 示 。 
| 让 ...else 语句 只 能 选择 两 种 结果 : 要 么 执行 真 ， 要么 执行 假 。 但 现在 有 两 种 以 上 的 选 
| 择 该 怎么 办 呢 ? 例如 ， 一 个 班 的 考试 成 绩 ， 如 果 在 90 分 以 上 ， 则 为 “优秀 ” 如 果 在 60 一 
| 90 分 之 间 ， 则 为 “良好 ” 如果 低 于 60 分 ， 则 为 “不 及 格 ”。 这 时 ， 可 以 使 用 elseif( 也 可 
| 以 写 做 else if) 语句 来 执行 。 该 语法 格式 为 : 
| iflexpr1){ 
statement]: 
}else if(expr2){ 
statment2; 
上 


else{ 
statementn; 


} 
elseif 语 句 的 流程 图 如 图 3.14 所 示 。 


图 3.13 让 .else 语句 流程 控制 图 图 3.14 elseif 语 句 的 流程 控制 图 


实例 043 ”网 页 版 九 九 乘法 表 


( 实例 位 置 : 配套 资源 \SL\03\043 ”视频 位 置 : 配套 资源 \SP\03\043 ) 


| 实例 说 明 
| 在 编程 世界 里 ， 算 法 是 一 门 独立 于 语法 、 函 数 之 外 的 知识 。 它 着 重 考 验 用 户 的 逻辑 思 


了 。62 。 
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维 能 力 并 且 与 数学 知识 息息相关 。 本 实例 通过 for0 循 环 语句 实现 网 页 版 九 九 乘法 表 ， 运行 | 
结果 如 图 3.15 所 示 。 


二 3 =9 
EE VIE 


Is.+z3=15|5 *+ 4 =205* 5 525 
#3 ale * 4 =24|6 *# 5 230 
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图 3.15 网 页 版 九 九 乘法 表 
实现 过 程 
具体 步 又 如 下 ; 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 一 层 循环 中 的 循环 变量 为 ga， 设 置 $a 的 初始 值 | 
为 1， 最 大 值 为 9， 并 且 每 执行 一 次 循环 就 做 一 次 自 增 运算 。 然 后 ， 定 义 内 层 循 环 中 的 循 | 
环 变 量 Sb， 设 置 $b 的 初始 值 为 1， 最 大 值 小 于 Sa， 并 且 做 自 增 运算 ， 最 后 ， 将 2 层 循环 控 | 
制 的 数据 输出 到 页 面 。 其 代码 如 下 : | 
<2php 
for($a = 1:$a < 10:$a+H){ /1 层 循环 
echo "<tr>": 
for($b = 1;$b <= $a:$b+H){ /2 层 循环 控制 1 层 循环 输出 
echo "<td>"; 


echo "$a * $b =".$a*$b; // 输 出 结果 
echo"</td>"; 


echo "</tr>"; 
} 


?> 


(2) 将 该 文件 存储 于 \MR\03\043 文件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 3.15 | 


所 示 。 
指点 迷津 : 

算法 不 是 一 朝 一 夕 就 可 以 掌握 的 ， 它 是 一 个 慢 慢 了 解 并 形成 思想 的 过 程 。 
技术 要 点 


本 实例 的 关键 点 是 利用 for 循环 中 , 第 二 层 循环 控制 第 一 层 循环 实现 指定 数据 的 输出 。 

for 循环 是 PHP 中 最 复杂 的 循环 结构 ， 其 语法 格式 为 : | 

for (exprl; expr2: expr3){ 

statement: 

) 

其 中 : exprl 在 第 一 次 循环 时 无 条 件 取 一 次 值 。expr2 在 每 次 循环 开始 前 求 值 。 如 果 值 | 

为 真 ， 则 执行 statement; 否则 ， 跳 出 循环 ， 继 续 往 下 执行 。expr3 在 每 次 循环 后 被 执行 。 | 

for 循环 语句 的 流程 控制 图 如 图 3.16 所 示 。 | 
Gs 


图 3.16 for 循环 语句 流程 控制 图 


实例 044 读 取 购 物 车 中 的 数据 


( 实例 位 置 配套 资源 \SL\03\044 视频 位 置 : 配套 资源 \SP\03\044 ) 


用 户 在 进行 数据 库 开 发 中 ， 小 型 的 数据 没有 必要 与 数据 库 进 行 交互 ， 可 以 直接 将 数据 


存 入 数组 ， 这 样 不 仅 可 以 节约 开发 时 间 ， 还 可 以 节省 服务 器 资源 。 本 实例 通过 对 数组 函数 
| 的 相关 操作 ， 实 现 读 取 数 组 购物 车 中 的 数据 ， 运 行 结果 如 图 3.17 所 示 。 


剩 全 
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图 3.17 读 取 购 物 车 中 的 数据 


| 实现 过 程 
| “具体 步骤 如 下 ， 
(1) 创建 PHP 脚本 文件 。 首 先 ， 定 义 字 符 串 变量 ， 并 且 在 变量 中 插入 “#” 作 为 字符 
有 分割 点 。 然 后 ， 利 用 GET 方式 接收 地 址 栏 传递 的 参数 。 当 $_GET[push] 的 值 等 于 1 时 ， 
输出 JavaScript 成 功 提示 。 当 $_GET[pop] 等 于 1 时 , 利用 字符 串 拆 分 函数 将 字符 串 变 量 以 # 
分 割 ， 并 分 别 保存 到 数组 之 中 。 最 后 ， 利 用 foreach 语句 将 字符 串 数组 中 的 value 值 输出 到 


.64 。 


| 
下 
上 目 
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页 面 中 。 其 代码 如 下 : 


<?php | 
$str= "宝贝 : 液晶 电脑 显示 器 # 一 口 价 : 900 元 # 运 费 ，30 元 (自理) "; /定义 字符 串 | 
这 $_GET[push] — D{ /通过 get 方式 取得 参数 | 
echo "<script>alert( 成 功放 入 购物 车 );</script>": /提示 消息 
} 1 
这 $_GET[pop] 一 TD){ // 通 过 get 方式 取得 参数 
$strexplode = explode("#",$str); /分 割 字符 串 | 
foreach($strexplode as $key => $value){ // 遍 历数 组 | 
?> 
<tr><td><?php echo $value;?></td></tr> // 输 出 结果 
<2php 
jr 
} 
3 


(2) 将 该 文件 存储 于 WMRWO3\044 文件 夹 下 ， 并 命名 为 index php。 运 行 结果 如 图 3.17 | 
所 示 。 | 
技术 要 点 | 

本 实例 的 关键 点 是 运用 foreach 语句 遍历 数组 ， 取 得 key 值 和 对 应 的 value 值 。foearch | 
循环 在 PHP 4.0 中 ， 其 擅长 处 理 数组 ， 是 遍历 数组 的 一 种 简单 方法 。 在 PHP 5.0 中 ， 新 增 | 
加 了 对 对 象 的 支持 。 该 语句 的 语法 格式 如 下 : | 


foreach (array_expression as $value) 
statement 


或 
foreach (array_expression as $key => $value) 
statement | 
forearch 语句 将 遍历 数组 array_expression, 每 次 循环 时 , 将 当前 数组 中 的 值 赋 给 $value 
(或 是 $key 和 S$value)。 同 时 ,数组 指针 向 后 移动 ， 直 到 遍历 结束 。 当 使 用 foreach 语句 时 ，| 
数组 指针 将 自动 被 重 置 ， 所 以 不 需要 手动 设置 指针 位 置 。 | 


实例 045 多 图 片上 传 


( 实例 位 置 : 配套 资源 \SL\03\045 视频 位 置 : 配套 资源 \SP\03\045 ) 


实例 说 明 | 
上 传 图 片 是 很 多 娱乐 网 站 所 必须 包含 的 模块 ， 其 优点 是 可 良好 地 与 用 户 互动 ， 由 用 户 | 
选择 喜欢 的 图 片 或 者 文件 上 传 。 大 量 的 用 户 为 网 站 传递 数 以 千 计 的 文件 和 图 片 ， 这 对 于 一 | 
个 企业 网 站 来 说 ， 是 一 个 相当 可 观 的 收益 。 简 单 的 单 文件 上 传 实现 起 来 相当 简单 ， 这 里 笔 | 
者 使 用 for 循环 语句 , 为 图 片上 传 增加 了 一 些 扩展 一 一 多 文件 上 传 。 本 实例 应 用 for 循环 控 | 
制 语 句 实现 将 多 图 片上 传 到 服务 器 指定 文件 夹 下 ， 一 次 可 以 上 传 4 张 以 内 的 图 片 ， 运 行 结 | 
果 如 图 3.18 所 示 。 | 
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图 3.18 多 图 片上 传 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 form 表单 ， 添 加 4 个 文件 域 和 “确定 上 传 ” 按 钮 ， 将 数据 通过 POST 方法 
提交 到 指定 的 位 置 。 
(2) 通过 $ POST 全 局 数组 获取 表单 中 提交 的 数据 , 应 用 for 循环 获取 表单 中 提交 的 
数据 ， 并 通过 $_FILES 全 局 数组 和 move_upload file0 函 数 完成 文件 的 上 传 操作 。 其 关键 代 
人 码 如 下 : 


<2php 
iftisset($_POST[sub]) { // 如 果 页 面 中 存在 变量 $_POST[sub] 程 序 向 下 执行 
for($a=1:$a<4:$a+H){ /for 循环 语句 
$name=$ FILES['file '.$a]; /将 图 片 信息 保存 在 变量 中 
Srand=rand(1,100000); /获取 1 一 100000 的 随机 数 
$name type=substr($name[mame'].-4.4):// 截 取 图 片 名 称 的 后 四 位 数据 并 保存 在 变量 中 
$time=microtime(); /获取 时 间 戳 微 秒 数 
$path='"upfiles/.(($rand+S$time).$name_type); // 上 传 路 径 
$dir="upfiles/'; // 文 件 夹 名 称 
$move = move_uploaded_file($name['tmp_name'],$path);// 将 图 片 移动 到 指定 文件 夹 下 
if($move—true){ 
echo "成 功 上 传 文件 ".($rand+$time).$name type."<br>"; 
} 
} 
} 
?> 
技术 要 点 


开发 本 实例 ， 需 要 对 文件 系统 的 知识 有 初步 的 了 解 ， 其 中 应 用 到 $_FILE 数组 和 
move_upload_file() 函 数 。move_upload_file(0) 函 数 的 语法 格式 如 下 : 
| bool move_uploaded file(string filename, string destination) 
move_uploaded_file() 函 数 的 参数 说 明 如 表 3.1 所 示 。 
表 3.1 move_uploaded file() 函 数 参 数 的 说 明 


| 参数 说 明 

| filename 必 选 参数 。 指 定 要 上 传 的 文件 地 址 

| destination 必 选 参数 。 上 传 到 服务 器 后 的 存储 目录 及 名 称 
】 。66 。 
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本 


脚下 留神 : 
应 用 POST 方法 上 传 文件 时 , 应 当 在 上 传 表单 的 <form> 标 记 中 添加 以 下 内 容 : enctype= | 
"multipart/form-data"。 | 


实例 046 控制 页 面 中 表情 图 的 输出 


( 实例 位 置 配套 资源 \SL\03\046 视频 位 置 配套 资源 \SP\03\046 ) 


实例 说 明 


break 语句 的 含义 是 结束 当前 for、foreach、while、do...while 或 者 switch 结构 的 执行 。 
本 实例 通过 break 语句 实现 控制 页 面 中 表情 图 的 输出 ， 运 行 结果 如 图 3.19 所 示 。 
[so hedk lesb le 


Oe men. [eeTxWP se 


高 可。 逢 htpy/192165.L194/S- 本 二 国 ” 


“和 侈 秆 " 呈 千 。 生 和 气 。 癌 欢 罗 | 


‖ @ memet| 和 FE 苇 PR 广 ” 蕊 105% 


图 3.19 控制 页 面 中 表情 图 的 输出 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 PHP 脚本 文件 。 当 单 击 “ 确 定 ”按钮 时 ， 利 用 switch 语句 选择 输出 的 图 片 ， 
并 通过 break 语句 跳出 当前 switch 语句 。 其 代码 如 下 : 


<2php | 
if($_GET[sub]){ // 通 过 get 方式 接收 参数 | 
switch($_GET['check]){ /switch 语句 | 
case "1": /如 果 值 为 1 | 
echo "<img src='image/] .gif >"; // 输 出 图 像 1 | 
break: /跳出 语句 | 
case "2": // 如 果 值 为 2 | 
echo "<img src='image/2.gif>": // 输 出 图 像 2 | 
break:; // 跳 出 语句 | 
case "3": // 如 果 值 为 3 | 
echo "<img src='image/3.gif >": // 输 出 图 像 3 | 
break: // 跳 出 语句 | 
case "4": // 如 果 值 为 4 | 
echo "<img src='image/4.gif >": /输出 图 像 4 | 
break:; /跳出 循环 | 
} | 

} 

ea 


(2) 将 该 文件 存储 于 \MR\03\046 文件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 3.19 


*。67 。 
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| break 关键 字 可 以 终止 当前 的 循环 ， 包 括 while、do...while、for、foreach 和 switch 在 
| 内 的 所 有 控制 语句 。 其 在 for 语句 中 应 用 的 示例 如 下 : 


for($i=1;$1<=4:;$i++){ /应 用 for 循环 控制 语句 输出 表情 头像 
这 $i 一 4){ // 判 断 变 量 是 否 等 于 4 
break; // 如 果 等 于 4， 则 使 用 break 语句 跳 转 循 环 
} 


本 实例 将 break 语句 与 switch 语句 联合 使 用 ， 并 控制 页 面 中 表情 图 的 输出 。 


实例 047 控制 页 面 中 数据 的 输出 数量 


( 实例 位 置 : 配套 资源 \SL\03\047 视频 位 置 配套 资源 \SP\03\047 ) 


| 实例 说 明 


| break 语句 可 以 指定 跳出 循环 的 层 数 ,一般 用 于 控制 条 件 方面 。 本 实例 通过 break 语句 
| 实现 控制 页 面 中 数据 的 输出 数量 ， 运 行 结果 如 图 3.20 所 示 。 


训 天 | 乱 htp//192168.1.194/S.- 偷 ~ 
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图 Internet | 保护 模式 : 禁用 珊 ” 或 105% ~ 


图 3.20 控制 页 面 中 数据 的 输出 数量 


| 实现 过 程 
| 具体 步 又 如 下 : 
(1) 创建 PHP 脚本 文件 。 首 先 ， 利 用 多 重 for 循环 雹 套 输 出 全 部 图 片 。 然 后 ， 在 多 


| 重 横 套 中 定义 并 条 件 语句 。 当 变量 Srand 中 的 随机 数值 为 2 时 ， 跳 出 3 重 循环 ， 否则， 正 
| 常 输出 图 片 。 其 代码 如 下 ; 


<?php 
for($a = 0:$a < 2;$a++){ /1 层 循环 
for($b = 0:$b < 2:$b++H){ //2 层 循环 
for($c= 0:$c< 4:8ctH){ /3 层 循环 
Srand = rand(1.4): /11~4 随机 数字 
echo "<img strc='image/$rand.gif >"; // 输 出 图 像 
} 
} 


} 
echo "<hr style='color:blue;>"; 
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for($a = 0;$a < 2:$a+H){ / 作 层 循环 
for($b =0:$b < 2:$b++){ /有 2 层 循 环 
for($c= 0:$c< 43$c+H{ /3 层 循 环 
Srand = rand(1.4): /11~4 随机 数字 
if($rand (= 2){ // 条 件 语 句 
echo "<img src=image/$rand.gif>"; /输出 图 像 
jelse{ 
break 3; // 结 束 3 个 层级 的 循环 
} 
; 
} 
' 


?> 


(2) 将 该 文件 存储 于 \MR\03\047 文件 夹 下 ， 并 命名 为 index.php。 运 行 结果 如 图 3.20 | 


所 示 
技术 要 点 
本 实例 运用 break 语句 跳出 指定 的 儿 重 循环 ， 其 语法 格式 如 下 : 


break $num; 
参数 $num 指定 要 跳出 儿 层 循环 。break 关键 字 的 控制 流程 如 图 3.21 所 示 。 


图 3.21 break 流程 控制 图 


实例 048 ”考试 成 绩 评定 标准 


( 实例 位 置 : 配套 资源 \SL\03\048 视频 位 置 : 配套 资源 \SP\03\048 ) 


实例 说 明 
本 实例 通过 于 条 件 语句 对 文本 框 输入 的 考试 成 绩 进行 评定 和 选择 , 运行 结果 如 图 3.22 
“69% L_ 
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[TEST 
成 绩优 秀 
图 3.22 考试 成 绩 评定 标准 
~ 实现 过 程 


A | 创建 index.php 文件 。 当 单 击 “ 评 定 ” 按 钮 时 ， 程 序 自动 利用 POST 方法 接收 数据 ， 
| 并 利用 站 语句 对 接收 的 数据 进行 判断 ， 再 用 echo 语句 输出 结果 。 其 代码 如 下 : 


<?php 
这 $ POST[sub]){ // 通 过 POST 方式 传递 参数 
这 $_ POST[text] — 100){ /当成 绩 为 100 时 
echo "成 绩优 秀 "; /输出 
} 
if($_POST[text] >= 60 and $ POST[text] < 100){ // 当 成 绩 大 于 等 于 60 小 于 100 时 
echo "成 绩 良 好 "; /输出 
} 
if($ POST[text] < 60){ /当成 绩 小 于 60 时 
echo "不 及 格 "; /输出 
} 
} 
| ?> 
| 技术 要 点 


| 让 语句 是 最 简单 的 条 件 判定 语句 , 它 对 某 段 程序 的 执行 附加 一 个 条 件 。 如 果 条 件 成 立 ， 
| 就 执行 这 段 程序 ， 否 则 就 跳 过 这 段 程序 ， 去 执行 下 面 的 程序 。 
| 本 实例 的 关键 点 是 让 语句 的 灵活 运用 。 当 expr 的 值 为 tue 时 ， 执 行 statementl 语句 。 
if(expr) {statement]:;} 
参数 说 明 : 
回 expr: 条 件 判断 语句 。 
回 statement1: 符合 条 件 的 执行 代码 。 


Web 技术 


本 章 读者 可 以 学 到 如 下 实例 : 

六 实例 049 通过 客户 端 卫 限制 投票 
次 数 

”实例 050 设计 论坛 登录 界面 

WI 实例 051 可 以 上 传 图 片 的 表单 

WI 实例 052 以 文本 域 的 形式 显示 数 
据 信 息 

WI 实例 053 ”验证 用 户 注册 信息 是 否 
合理 

WI 实例 054 省 市 级 联动 菜单 

WI 实例 055 省 市 县 级 联动 菜单 
实例 056 ”实现 复 选 框 中 的 全 选 、 
反选 和 不 选 

WI ”实例 057 上传 图 片 预览 

WI 实例 058 通过 下 拉 列 表 选 择 头 像 

WI 实例 059 日 期 选择 器 

WI 实例 060 在 页 面 右 下 角 弹 出 渐 显 
的 广告 窗口 

WI 实例 061 树 形 导 航 菜单 


各 有 香 理 理 理 怠 吾 吾 


各 怠 


吾 于 于 于 于 至 


CE 
天 


实例 062 
实例 063 
实例 064 
实例 065 
实例 066 
实例 067 
实例 068 
实例 069 
影响 

实例 070 
实例 071 


章 


收缩 式 导航 菜单 

控制 登录 用 户 的 过 期 时 间 
统计 用 户 在 线 时 间 
限制 用 户 访问 网 站 的 时 间 
SESSION 更 换 聊 天 室 界 面 
掌控 登录 用 户 的 权限 
屏蔽 页 面 刷新 对 计数 器 的 


SESSION 购物 车 
清理 SESSION 缓存 提高 网 


站 访问 的 效率 


实例 072 
实例 073 
实例 074 
实例 075 
实例 076 
实例 077 


限制 上 传 文件 的 大 小 

限制 上 传 文件 的 类 型 

上 传 多 个 文件 到 服务 器 
通过 header0 函 数 进行 下 载 
重新 定义 上 传 文件 的 名 称 
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实例 049 通过 客户 端 卫 限制 投票 次 数 


( 实例 位 置 : 配套 资源 \SL\04\049 ) 


实例 说 明 


本 实例 将 制作 一 个 简单 的 投票 系统 ， 通 过 获取 客户 端 他 地 址 来 限制 用 户 的 投票 次 数 ， 


每 个 IP 只 可 以 投票 一 次 ， 如 果 重 复 投票 则 给 出 提示 信息 ， 运 行 结果 如 图 4.1 所 示 。 


在线 投票 1 画 

加 A 你 已经 投 过 村 了 4 

el LE | 
全 


图 4.1 在 线 投票 图 4.2 重复 投票 将 弹出 提示 信息 


实现 过 程 


获取 客户 端 他 地 址 需要 使 用 $_SERVER[] 全 局 数组 中 的 $_SERVER['REMOTE_ADDR'] 


参数 。 本 实例 将 客户 端 他 地 址 存放 到 数据 库 中 ， 当 用 户 提交 投票 时 ， 使 用 迁 ..else 语句 判断 
该 了 P 在 数据 库 中 是 否 存 在 ， 从 而 实现 通过 客户 端 亿 地址 限制 投票 次 数 。 其 具体 代码 如 下 : 


<2php 

/连接 数据 库 

S$conn=mysql_connect("localhost","root","111"); 

mysql_select_db("db_database04",$conn); 

mysql_query("set names utf8"); 

Sip=$_SERVER['REMOTE_ADDR']: // 获 取 客 户 端 卫 地 址 
$insert="insert into tb_vote(IP)values($ip)": /定义 添加 数据 语句 

$select="select * from tb_vote where ip='$ip"; /定义 查询 语句 ， 查 询 瑟 地 址 在 数据 库 中 是 否 存在 
iflisset($_POST['Submit]) and $_ POST['Submit] 一 "提交 投票 ){ /判断 按钮 的 执行 操作 


$value=mysql_query($select,$conn): // 执 行 查 询 操作 
if(mysql num rows($value)—0){ // 判 断 查 询 结果 是 否 等 于 0 
$result=mysql_query($insert,$conn);// 如 果 等 于 0, 执行 添加 语句 , 将 他 地 址 添加 到 数据 库 中 
if($result) { // 判 断 添加 操作 是 否 成 功 执行 
echo "<script>alert(' 投 票 成 功 ! "):window.location.href='index.php':</script>"; ”// 如 果 成 功 执行 ， 
则 提示 投票 成 功 
}else{ 
echo "<script>alert(' 投 票 失败 ! "):window.location.href="index.php':</script>":// 否 则 提示 投票 
失败 
} 
}else{ 
echo "<script>alert( 您 已 经 投 过 票 了 ! ");window.location href~'index.php';</script>"; 
} 
} 
es 


。72 。 
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本 实例 主要 使 用 $_SERVER[] 全 局 数组 中 的 $_ SERVER[REMOTE ADDR'] 参 数 来 获取 | 
客户 端 卫 地 址 。$_SERVER[ ] 全 局 数组 包含 由 Web 服务 器 创建 的 信息 , 应 用 该 数组 可 以 获 | 
取 服 务 器 和 客户 端 配置 及 当前 请 求 的 有 关 信 息 。 下 面 对 $_SERVER[ ] 数 组 进行 介绍 ， 如 | 
表 4.1 所 示 。 


表 4.1 $_SERVERI[] 全 局 数组 | 

数组 元 素 说 明 | 
$_SERVER['SERVER ADDR]] 当前 运行 脚本 所 在 服务 器 的 也 地址 | 
当前 运行 脚本 所 在 服务 器 主机 的 名 称 。 如 果 该 脚本 运行 在 一 个 “| 

虚拟 主机 上 ， 该 名 称 则 由 那个 虚拟 主机 所 设置 的 值 决定 | 
访问 页 面 时 的 请 求 方法 , 例如 ,“GET”、“HEAD”、“POST”、 | 
$_SERVER['REQUEST_ METHOD'] “PUT”。 如 果 请 求 的 方式 是 HEAD，PHP 脚本 将 在 送出 头 信 | 
息 后 中 止 〈 这 意味 着 在 产生 任何 输出 后 ， 不 再 有 输出 缓冲 》 | 


$_SERVER['SERVER_NAME'] 


$_SERVER['REMOTE ADDR' 正在 浏览 当前 页 面 用 户 的 他 地 址 | 
览 当 各 基 | 

$_SERVERIREMOTE HOST'] 正在 浏览 当前 页 面 用 户 的 主机 名 。 反 向 域名 解析 基于 该 用 户 的 | 
REMOTE ADDR | 

$_SERVER[REMOTE PORT' 用 户 连接 到 服务 器 时 所 使 用 的 端口 | 


当前 执行 脚本 的 绝对 路 径 名 。 注 意 : 如 果 脚 本 在 CLI 中 被 执行 ， 
$_SERVER['SCRIPT_ FILENAMEI] 作为 相对 路 径 ， 例 如 file php 或 者 .filephp，$_SERVER['SCRIPT 
FILENAME'] 将 包含 用 户 指定 的 相对 路 径 
服务 器 所 使 用 的 端口 ， 默 认为 “80”。 如 果 使 用 SSL 安全 连接 ， 
则 这 个 值 为 用 户 设置 的 HTTP 端口 
$_SERVER['SERVER_SIGNATURE'] | 包含 服务 器 版 本 和 虚拟 主机 名 的 字符 串 
$_ SERVER[DOCUMENT ROOT' 当前 运行 脚本 所 在 的 文档 根 目录 ， 在 服务 器 配置 文件 中 定义 | 


$_SERVER['SERVER_PORT'] 


实例 050 设计 论坛 登录 界面 | 


( 实例 位 置 : 配套 资源 \SL\04\050 视频 位 置 : 配套 资源 \SP\04\050 ) | 


实例 说 明 

论坛 是 许多 网 站 不 可 或 缺 的 模块 之 一 , 它 提供 一 
个 空间 ， 使 人 们 相互 之 间 能 够 进行 各 种 沟通 和 交流 。 
设计 论坛 模块 的 第 一 个 步骤 就 是 设计 论坛 登录 界面 ， 
让 用 户 根据 自己 注册 的 用 户 名 和 密码 登录 论坛 。 在 本 
实例 中 , 笔者 设计 了 一 个 简单 的 论坛 登录 界面 ,效果 
如 图 4.3 所 示 。 


企业 塘 理 信息 管理 系统 
a 


实现 过 程 图 4.3 ”论坛 登录 界面 
具体 步骤 如 下 : 
(1) 利用 Dreamweaver 开发 工具 创建 一 个 动态 PHP 页 ， 并 将 其 保存 为 “index.php”。 
Se 
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| 的 宽度 。 


全 A 


(2) 添加 一 个 表单 ， 在 表单 中 插入 一 个 3 行 2 列 的 表格 。 调 整 表格 各 行 的 高 度 和 列 


(3) 设置 表格 的 align 属性 为 “center”， 使 表格 在 表单 中 始终 居中 显示 。 

(4) 向 表格 单元 格 中 输入 用 户 名 称 和 密码 信息 ， 并 添加 文本 字段 和 按钮 。 

(5) 设置 “密码 ”文本 字段 的 类 型 (type) 属性 为 “password”， 使 其 以 掩 码 的 形式 
隐藏 真实 密码 。 


其 主要 代码 如 下 : 
<form action="" method="post"> 
<table align="center"> 
<tr><td> 用 户 名 </td><td><input type="text" name="te" size="20" /></td></tr> 
<tr><td> 密 &nbsp;&nbsp; 码 </td><td><input type="password" name="tex" size="22" 
| P<htd></t> 
<tr><td align="left"><input class="two"type="submit" name="sub" value="&nbsp;&nbsp; 
| &nbsp;&nbsp;&nbsp;&nbsp;&nbsp;" /></td> 


<td align="left"><input class="three" type="reset" name="res" value="&nbsp;énbsp; 


| &nbsp:&nbspi&nbsp:&nbsp:&nbsp:"/><ftd><ltr> 


</table> 
</form> 


在 设计 论坛 登录 界面 时 ， 主 要 采用 表格 标签 进行 界 2 i 
面 布 局 。 本 实例 设计 了 一 个 3 行 2 列 的 表格 ， 如 图 4.4 = 


所 示 。 图 4.4 “利用 表格 标签 布局 
这 样 , 一 个 论坛 登录 界面 的 轮廓 就 形成 了 。 接 下 来 还 

需要 为 表格 设置 背景 图 像 。 利 用 表格 标签 的 background 属性 就 可 以 为 表格 添加 背景 图 像 了 ， 

代码 如 下 : 


<table width="392px" height="249px" align="center"><tr><td background="pic/tablebk jpg"> 


实例 051 可 以 上 传 图 片 的 表单 


( 实例 位 置 : 配套 资源 \SL\04\051 ) 


许多 大 型 网 站 为 了 吸引 用 户 ， 会 分 配 一 些 ER 


空间 供用 户 使 用 。 例 如 ， 大 家 经 常 使 用 的 电子 夭 巴 升 允 本 开发 责 洒 床 ， 为 开 发 提 估 系统、 是 全 而 、 吧 和 可 开发 到 
邮箱 、QQ 个 人 空间 等 。 为 了 能 够 让 用 户 在 个 人 CE 


| 空间 中 放置 自己 的 内 容 ， 网 站 都 会 提供 文件 、 
| 图 片 等 信息 的 上 传 功能 。 例 如 ， 在 QQ 个 人 空 


| 间 中 ， 用 户 可 以 将 自己 的 照片 上 传 上 去 ， 供 好 mm 


友 欣 赏 。 本 实例 中 ， 我 们 利用 文件 域 实现 图 片 一 | 
的 上 传 功能 ， 效 果 如 图 4.5 所 示 。 图 45 可 以 上 传 图 片 的 表单 
。74 。 
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实现 过 程 


具体 步骤 如 下 : 

(1) 创建 动态 PHP 文件 ， 并 命名 为 mdex.php。 

(2) 添加 一 个 表单 ， 将 type 属性 设置 为 fle。 其 代码 如 下 : 
<form action="" method="post" enctype="multipart/form-data"> 

<input type="file" name="upfile" size="20" /> | 
<input class="two"type="submit” name="sub" value="&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; | 
&nbsp;&nbsp;" /> | 
</form> | 
(3) 利用 <table> 标 签 编写 网 页 框架 。 | 
(4) 利用 编码 实现 上 传 功能 。 其 核心 代码 如 下 : 


<2php 
这 $_POST[sub]){ // 单 击 上 传 按钮 | 
if($_FILES['upfile']['name’] — "){ /判断 上 传 文件 名 称 是 否 为 空 | 
echo "<script>alert( 上传 内 容 为 室 ):</script>"; | 
}else{ | 
$info = $_FILES['upfile']: // 将 上 传 文件 信息 ， 保 存在 数组 中 | 
if($info['size'] > 0 && $info['size'] < 1024 * 8000){ // 判 断 上 传 文件 的 大 小 | 
$dir = "upfiles/"; // 定 义 变量 | 
$name = $info[mame']: // 设 定 文件 名 称 | 
Srand = rand(0.10000000): | 
$name = $rand.date('YmdHis').$name; | 
$path = "upfiles/. $name; | 
if(!is_dir($dir){ // 判 断 文 件 夹 是 否 存在 ， 如 果 不 存在 则 创建 一 个 文件 夹 | 
mkdir($dir); | 
} | 
$move = move_uploaded file($info['tmp_name'].$path); /将 上 传 文件 移动 到 指 | 
定位 置 | 
if($move — true){ | 
echo "<script>alert( 上 传 文件 成 功 ):</script>": | 
} | 
Jelse{ | 
echo "<script>alert( 上传 文 件 过 大 "):<Jscript>"; | 
} | 
} | 
} | 
?> | 
技术 要 点 


在 本 实例 中 , 实现 照片 上 传 的 主要 方式 是 利用 文件 

域 让 用 户 加 载 本 地 文件 ， 然 后 应 用 PHP 函数 move。 了 Fwemppwampomtdocsw Ca | 
uploaded_file 实现 文件 的 上 传 ， 效 果 如 图 4.6 所 示 。 | 
move_uploaded file0 函 数 ; 将 上 传 的 文件 移动 到 新 图 46 文本 域 加 载 本 地 文件 。 | 
SB . 
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bool move_uploaded file ( string filename, string destination ); 
; 参数 说 明 ， 

请- string filename 指定 的 文件 是 合法 的 上 传 文件 。 
回 string destination: 定义 上 传 文件 的 名 称 。 


实例 052 ”以 文本 域 的 形式 显示 数据 信息 


( 实例 位 置 : 配套 资源 \SL\04\052 ) 


| 实例 说 明 
| 在 开发 网 站 的 过 程 中 , 一般 涉 及 到 用 户 注册 的 


| 网 站 模块 中 都 有 一 个 用 户 注册 的 服务 条 款 .个别 的 Ce 

| 服务 条 款 以 整个 网 页 进行 显示 , 但 是 有 的 网 站 用 户 en 

| 注册 的 服务 条 款 篇 幅 过 长 ， 比 较 浪费 网 络 空间 ,就 

| 不 适合 使 用 整个 页 面 来 显示 了 , 最 好 的 方式 就 是 以 上 

| 文本 域 的 形式 来 显示 用 户 注册 的 服务 条 款 , 既 节省 -| 

| 页 面 ， 又 美观 大 方 。 运 行 本 实例 ,在 文本 域 中 显示 

| 用 户 注册 的 服务 条 款 ， 效 果 如 图 4.7 所 示 。 图 47 以 文本 域 形式 显示 数据 信息 


现 过 程 


具体 步骤 如 下 : 
(1) 创建 index.php 文件 , 编写 文本 域 代码 ， 并 通过 PHP 变量 传递 初始 值 。 其 代码 如 下 : 
<2php 
$str = "用 户 不 得 发 布 违 反 国家 行政 法 规 的 内 容 。 /定义 变量 
不 得 发 布 违反 社会 道德 的 内 容 。"; 
?> 
<form action="" method="post"> 
<div align="center"> 
<textarea name="txt" id="one" cols="30" rows="6"><?php echo $str;?></textarea> 
<br> 
<br> 
<input type="submit" name="agreen" id="agreen" value=" 接 受 " /> 
&nbsp:&nbsp:&nbsp:&nbsp: 
<input type="button" name="disagreen" id="disagreen" value=" 不 接 受 "/> 
</div> 
</form> 


| 技术 要 点 
| 本 实例 应 用 表单 中 的 文本 域 显 示 信息 ， 主 要 就 是 设置 文本 域 的 初始 值 。 代 码 如 下 : 
<textarea name="test" cols="45" rows="8" id="test"><?php echo $myrow[text]:?></textarea> 
J .76 . 
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参数 说 明 : 

name: 文本 域 的 名 称 。 
cols: 文本 域 的 字符 宽度 。 
rows: 文本 域 显示 的 行 数 。 


实例 053 ”验证 用 户 注册 信息 是 否 合 理 


( 实例 位 置 : 配套 资源 \SL\04\053 ) 


实例 说 明 


本 实例 主要 实现 判断 用 户 输入 的 注册 信息 是 否 合理 ， 当 用 户 输 入 的 注册 信息 不 合 


给 出 相应 的 提示 ， 运 行 结果 如 图 4.8 所 示 。 


suYvU 国手 联盟 设 为 首页 /加 入 收藏 / 联系 我 们 


用 户 名 : 
密码 : 
确认 窑 码 : 
tl: 
email : mingnisof@mingrisof com 
本 Frsms 


EL 


服务 热量 : 0451-0431-84972268 0431-B4976961 0431-64976962 http://www_mingrisoft com 
图 4.8 验证 用 户 注册 信息 是 否 合 
实现 过 程 
具体 步骤 如 下 : 
(1) 创建 index.php 文件 ， 并 设计 用 户 注册 信息 页 面 ， 效 果 如 图 4.8 所 示 。 
(2) 创建 javascript 脚本 文件 ， 完 成 验证 用 户 注册 信息 是 否 合理 ， 代 码 如 下 : 
<script language="javascript"> 
function checkemail(email){ 
Var str=email; 
/在 JavaScript 中 ， 正 则 表达 式 只 能 使 用 "/" 开 头 和 结束 ， 不 能 使 用 双 引 号 
Var Expression=AWw+([-+.] 人 w+)*@\w+([-.] 人 w+)*\\w+([-.] 人 w+)*/; 。” // 定 义 E-mail 地 址 格式 
Var objExp=new RegExp(Expression); 
if(objExp.test(str)==true){ 
Tetum true; 
Jelse{ 
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function checktel(tel) { 
Var str=tel; 

/在 JavaScript 中 ， 正 则 表达 式 只 能 使 用 "/" 开 头 和 结束 ， 不 能 使 用 双 引 号 
var Expression=/(\d{3}-)(\d{8})$|(\d{4}-)0d{7))8/; // 定 义 电 话 格式 
Var objExp=new RegExp(Expression); 

这 objExp.test(stD) 一 trne){ 
Tetum true; 
}else{ 
Teturn false; 
b 
} 
function checkitO{ // 自 定义 函数 
if(forml .name.value—""){ 1// 判 断 用 户 名 是 否 为 空 
alert(" 请 输入 用 户 名 !"); 
forml.name.select(); 
return false; 
} 
if(forml.pwd.value—""){ /判断 密码 是 否 为 空 
alert(" 请 输入 密码 !"); 
forml.pwd.selectO; 
return false; 
} 
if(form1.qpwd.value—""){ /判断 确认 密码 是 否 为 空 
alert(" 请 输入 确认 密码 1"); 
forml.qpwd.select|O; 
return false; 


} 
if(forml1.pwd.value!=forml.qpwd.value){ /判断 两 次 输入 的 密码 是 否 一 臻 
alert(" 了 两 次 输入 的 密码 不 一 致 !7; 
forml.pwd.selectO; 
return false : 


if(forml.email.value—""){ // 判 断 E-mail 是 否 为 空 
alert(" 请 输入 email!"); 
forml.email.select(); 
return false; 


} 
if(!checkemail(form1.email.value)){ // 判 断 E-mail 地 址 格式 是 否 正 确 
alert(" 您 输入 Email 地 址 不 正确 1"); 
forml.emailselectO: 
Tetum false; 


} 
if(form!l .tel.value—""){ /判断 电话 是 否 为 空 
alert(" 请 输入 电话 !"); 
forml .tel.selectO; 
Tetum false; 
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} 
if(!checktel(form!l .tel.value)){ // 判 断 电 话 号 码 格式 是 否 正 确 
alert(" 您 输入 的 电话 不 正确 !"); 
form!l .tel.select(: 
Tetum false; 
} 
Tetum true; 
} 
</script> 
技术 要 点 


本 实例 主要 通过 JavaScript 脚本 技术 来 实现 判断 用 户 输入 的 注册 信息 是 否 合 


实例 054 省 市 级 联动 菜单 


( 实例 位 置 : 配套 资源 \SL\04\054 视频 位 置 : 配套 资源 \SP\04\054 ) 


实例 说 明 | 
在 进行 网 站 开发 的 过 程 中 ， 经 常会 用 到 相互 关联 的 菜单 。 例 如 ， 省 、 市 、 县 三 级 联动 
或 者 省 市 两 级 联动 菜单 。 在 本 实例 中 ， 笔 者 讲解 如 何 实现 省 市 两 级 联动 菜单 ， 运 行 效果 如 | 
图 4.9 所 示 。 | 


营 市 级 瑟 动 基 旬 


二 


EE 


图 4.9 省 市 级 联动 菜单 
实现 过 程 
具体 步骤 如 下 : 
(1) 创建 脚本 文件 ， 引 入 CSS 样式 表 和 JavaScript 脚本 。 编 写 一 级 下 拉 列 表 ， 设 置 | 
<option> 标 签 属性 “value” 的 值 。 其 代码 如 下 : | 


<select id="select1"> 
<option value="" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
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<option value="2"> 辽 宁 </option> 
</select> 


| (2) 编写 JavaScript 代码 ， 当 选 则 一 级 下 拉 列 项 时 ， 触 发 change 事件 。 代 码 如 技术 

| 要 点 中 所 示 。 
| 本 实例 通过 设置 change 事件 实现 联动 的 下 拉 列 表 , 并 且 通 过 一 级 下 拉 列 表 传递 的 参数 
| 不 同 ， 显 示 不 同 的 两 级 下 拉 列 表 信息 。 实 现 这 些 功能 的 JavaScript 代码 如 下 : 


S$("#select1").change( fonction0O { 
var id = $("#select1").val(); 
iflid—= D{ 
$.get(index.php', null, function(data){ 
$("span").empty(); 
| $("span").append("<select><option> 长 春 </opton><option> 松 原 <opton><option> 
”通辽 </opton></select>"); 
| )); 
}else{ 
$.get('index.php', null, function(data) { 
$("span").emptyO; 
| $("span").append("<select><option> 大 连 </opton><option> 旅 顺 </opton><option> 
| 钱 鱼 圈 </opton></select>"); 
| »; 
} 
DE 


实例 055 省 市 县 级 联动 菜单 


( 实例 位 置 : 配套 资源 \SL\04\055 ) 


实例 说 明 
在 实例 054 中 ， 笔 者 已 经 讲解 如 何 实现 两 级 联动 菜单 ， 下 面 笔者 向 用 户 讲解 如 何 实现 
| 省 、 市 、 县 三 级 联动 菜单 。 运 行 本 实例 ， 效 果 如 图 4.10 所 示 。 


省 市 县 级 联动 匡 单 
| 可 


于 | 农安 | 


| 图 4.10 省 市 县 级 联动 菜单 
J ‘80°. 
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实现 过 程 
具体 步骤 如 下 : 


(1) 创建 脚本 文件 ， 并 命名 为 index.php。 然 后 创建 form 表单 ， 并 编写 下 拉 列 表 框 ， 
定义 两 级 联动 和 三 级 联动 的 下 拉 列 表 选项 ， 代 码 如 下 : 


<select id="select1"> 
<option value="" selected> 请 选择 </option> 
<option value="1"> 吉 林 </option> 
<option value="2"> 辽 宁 </option> 
</select> 
<span id='two'></span> 
<span id='three'></span> 


(2) 创建 JavaScript 脚本 文件 ， 当 触发 change 事件 时 ， 实 现 联 动 效 果 ， 代 码 如 下 : 


S$("#select1").change( function|) { 
var id = $("#select1").val(); 
ifid— D{ 
$.get(index.php', null, function(data){ 
S$("#two").empty(); 
$("#two").append("<select id='select2'><option> 请 选择 </opton><option value=1> 
长 春 </opton><option value='2'> 松 原 </opton></select>"); 
$("#select2").change( function0 { 
Var page = $("#select2").val(); 
if(page — 1){ 
$("#three").emptyO; 
$("#three").append("<select><option> 双 阳 </opton><option> 农安 


</opton></select>"); 
}else{ 
if(page — 2){ 
S$("#three").emptyO:; 
$("#three").append("<select><option> 乾 安 </opton><option> 大 
安 </opton></select>"); 


D); 
D); 
}else{ 
$.get(index.php', null, function(data){ 
S$("#two").emptyO: 
$("#two").append("<select id='select3'><option value='1> 大 连 </opton><option 
value='2 人 > 旅顺 </opton></select>"); 
$("#select3").change( functionO { 
Var page = $("#select3").val(); 
if(page — D{ 
$("#three").emptyO); 
$("#three").append("<select><option> 西 岗 </opton><option> 沙 河口 
</opton></select>"); 
}else{ 
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这 page 一 2){ 
S$("#three").empty(); 
| $("#three").append("<select><option> 金 州 </opton><option> 瓦 
| 房 店 </opton></select>"); 
# | ny 
| | 
六 
yy 

| } 

| D; 

| 技术 要 点 


| 本 实例 与 实现 两 级 联动 的 菜单 思路 大 臻 相同， 只 不 过 套用 多 层 的 直 ..else 语句 ， 来 实 
| 现 省 、 市 、 县 三 级 联动 菜单 。 
实例 056 ”实现 复 选 框 中 的 金 选 、 反 选 和 不 选 
( 实例 位 置 : 配套 资源 \SL\04\056 视频 位 置 配套 资源 \SP\04\056 ) 
”实例 说 明 


| 复 选 框 应 用 在 用 户 注 册 系 统 中 , 如 个 人 爱好 选择 等 。 本 实例 所 讲述 的 三 个 操作 : 全 选 、 
| 反选 、 不 选 ， 只 是 根据 实际 情况 ， 对 复 选 框 实现 的 快捷 操作 。 运 行 本 实例 ， 全 选 的 效果 如 
| 图 4.11 所 示 。 
四 oa 
首页 。 坊 程 避 典 外 菇 。 编程 癌 册 介绍 。 篇 民 司 由 在 配 服 务 会 员 各 理 浸出 登录 
外 会 员 数据 管理 
wma 部 沁 相 日本 
”i 二 而 匡 画面 
| 图 4.11 实现 全 选 
| 实现 过 程 
具体 步骤 如 下 : 


| (1) 创建 js 文件 夹 , 编写 regjs 脚本 文件 。 在 regjs 中 ,编写 自 定义 函数 ,实现 全 选 、 
反选 和 不 选 功能 。regjjs 文件 的 关键 代码 如 下 : 
| function uncheckAll(form!l ,status) { 1/ 不 选 

var elements = forml.getElementsByTagName(input): /获取 input 标签 


。82 . 


第 生 阐 Wb 技术 一 wy 


for(var i=0; i<elements length: i++){ // 根 据 标签 的 长 度 执行 循环 | 
if(elements[i] type 一 'checkbox { // 判 断 对 象 中 元 素 的 类 型 | 
ielements[i].checked 一 true){ // 判 断 当 checked 的 值 为 tue 时 | 
elements[i].checked=false: // 为 checked 赋值 为 false | 
} | 

} | 
finction checkAll(forml ,status){ // 全 选 | 
Var elements = form!] .getElementsByTagName('input’); | 
for(var i=0; i<elements.length; i++){ | 
if(elements[i].type — 'checkbox') { | 
这 elements[i].checked 一 false){ | 
elements[i].checked=true; | 
} | 
} | 
} | 
} | 
function switchAll(forml,status) { /反选 | 
Var elements = form!] .getElementsByTagName('input’); | 
for(var i=0; i<elements length: i++H){f | 
if(elements[il.type — 'checkbox"){ | 
if(elements[i].checked—true) { | 
elements[i].checked=false; | 
}else ifelements[i].checked 一 false){ | 
elements[i].checked=true; | 
} 上 
} | 
} | 
} | 
(2) 创建 index.php 页 面 ， 输 出 会 员 信息 ， 并 添加 图 像 按钮 。 通 过 onclick 事件 调用 | 
JavaScript 自 定义 函数 ， 实 现 全 选 、 反 选 、 不 选 和 删除 的 功能 。 其 关键 代码 如 下 : | 
‘<script language="javascript" sre="js/reg.js"></script> | 
<form method="post" name="form]" id="form]1" action="index_ok.php"> | 
<tr> | 
<td width="62" align="center"><input name="conn id[]" type="checkbox" id="conn id[]" value="1" | 
P</htd> | 
<td width="242"> 欧 阳 </td> | 
<td width="243">PHP</td> | 
<td width="485"> 部 门 经 理 </td> | 
<td width="485">29</td> | 
</t> | 
<tr> | 
<td colspan="5" align="center"><!-- 通 过 onclick 事件 调用 自 定义 函数 ， 执 行 相应 的 操作 --> | 
<img stc="images/bg_19-20.jpg" onclick="checkAll(forml,status)" width="62" height="25" /> | 
<img src="images/bg_14-14.jpg" onclick="switchAll(forml,status)"” width="62" height="25" /> | 
<img src= "images/bg 07-08.jpg" width="62" height="25" onclick="uncheckAll(form!,status)" /> | 
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<input type="image" name="imageField" src="images/bg 14.jpg"/> 
</td> 


</tr> 
国内 | 坡 术 要 点 


复 选 框 的 全 选 、 反 选 和 不 选 主要 通过 JavaScript 脚本 的 自 定义 函数 来 完成 。 
| (1) 在 通过 JavaScript 脚本 中 的 自 定义 函数 完成 复 选 框 的 全 选 、 反 选 和 不 选 功能 中 ， 
| 应 用 的 是 getElementsByTagName, 获取 指定 标签 的 名 称 ， 其 返回 值 是 一 个 包含 标签 信息 的 
| object。 
| (2) 根据 getElementsByTagName 标签 返回 的 对 象 ， 判 断 标签 类 型 (type) 的 值 是 否 
| 为 checkbox。 
(3) 当 标 签 类 型 type 的 值 为 checkbox 时 ， 为 标签 中 的 checked 赋值 。 当 checked 的 
值 为 true 时 ， 为 它 赋值 为 false; 当 checked 的 值 为 false 时 ， 为 它 赋值 为 tue。 
(4) 在 页 面 中 ， 通 过 script 标签 调用 js 文件 夹 下 的 文件 ， 应 用 onclick 事件 调用 自 定 
| 义 函 数 ， 完成 全 选 、 反 选 和 不 选 功能 的 实现 。 


| 实例 057 上 传 图 片 预 览 


( 实例 位 置 : 配套 资源 \SL\04\057 ) 


”实例 说 明 
上 传 图 片 时 最 好 为 程序 设置 预览 功能 ， 防 止 用 户 意外 传 错 图 片 。 还 有 一 个 很 重要 的 模 


| 块 就 是 获取 图 片 的 地 址 ， 方 便 用 户 网 站 的 推广 。 运行 本 实例 ， 完 成 图 片 预览 和 图 片 地 址 获 
| 取 的 功能 ， 运 行 结果 如 图 4.12 和 图 4.13 所 示 。 


ed| 


[Chaum [|| GE ] [有 
| 


| 图 4.12 上 传 图 片 预览 图 4.13 获取 图 片 地 址 
| 实现 过 程 
| 1) 创建 indexphp 文件 ,引入 CSS 样式 和 injs 文件 以 及 jQuery 库 文件 jquery-13.2js。 
| 创建 form 表单 ， 设 置 文 件 域 属性 ， 添 加 预览 图 片 、 图 片 地 址 和 清除 的 按钮 。 其 代码 如 下 : 
| rs 


<tr> 


J See 
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<td align="center"><div class="n"></div> 


<table align="center"> | 
<tr> | 
<td> | 
<span class="0"> | 
<span class="e"><input class="one" id="one" type="file"></span> | y 
<input class="one" id="two" type=button value=" 预 览 图 片 "> | 
<input class="one" id="three" type=button value=" 图 片 地 址 "> 


<input class="one" id="four" type=button value=" 清 除 " > 
</span> 

</td> | 

</tr> | 

</table> 
</td> 
</tr> 

</table> 


(2) 创建 JavaScript 脚本 文件 injs， 代 码 如 技术 要 点 中 所 示 。 


本 实例 通过 JavaScript 的 click 事件 ， 实 现 图 片 的 预览 、 获 取 地 址 和 清除 上 传 文本 框 信 
息 的 功能 。 其 核心 代码 如 下 :、 


S$(document) .ready(function(){ 
$("#two").click(functionO|{ // 单 击 预览 图 片 
var value = $("#one").valO; // 取 得 上 传 地 址 
这 value —""){ /判断 地 址 是 否 为 空 
alert(" 地 址 为 空 "); 
}else{ 
$(".n").append("<img id='five' strc="+valuet+">");”// 显 示 图 片 
S$("#two").click(functionO{ 
S$(".n").emptyO; 
$(".n").append("<img id='five' src="+value+">"); 
六 
} 
D; 
$("#three").click(functionO{ // 显 示 图 片 地址 
Var value = $("#one").val(); | 
这 value — ""){ 
alert(" 地 址 为 空 "); | 
j}else{ | 
alert(value): | 
} | 
D; | 
$("#four").click(functionO){ // 清 除 文本 框 信息 | 
$(".e").emptyO; | 
$(".e").append("<input class='one' 1d='one' type='file'>"); ! 
D; | 
)》; | 
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实例 058 通过 下 拉 列 表 选 择 头 像 


( 实例 位 置 : 配套 资源 \SL\04\058 ) 


实例 说 明 


| 在 腾讯 的 QQ 系统 中 ， 我 们 可 以 通过 单 击 头像 而 实现 更 换 新 的 头像 。 其 实 这 个 功能 相 
| 对 来 说 是 比较 简单 的 。 运 行 本 实例 ， 通 过 下 拉 列 表 实现 头像 的 选择 ， 效 果 如 图 4.14 所 示 。 


男性 -| 
区 一 百 


的 


| 
Se 


| 图 4.14 通过 下 拉 列 表 选 择 头像 
| 实现 过 程 


具体 步骤 如 下 : 
| (1) 创建 index.php 文件 ， 引 入 CSS 样式 和 JavaScript 脚本 文件 injs 以 及 jQuery 库 ， 
| 编写 下 拉 列 表 和 标签 ， 具 体 代 码 如 下 : 


<table align="center"> 
<tr> 
<td> 
<select name="select"> 
<option value="> 请 选择 性 别 </option> 
<option value="nan"> 男 性 </option> 
<option value="nv"> 女 性 </option> 
</select> 
<div id="o0"></div><div id="n"></div> 
</td> 
</t> 
</table> 


| (2) 创建 JavaScript 脚本 in.js 文件 ， 代 码 如 技术 要 点 中 所 示 。 

| 技术 要 点 

| 本 实例 通过 JavaScript 的 change 事件 和 实例 “省 市 级 联动 菜单 ”中 的 两 级 联动 菜单 实 
| 现 。 核 心 代码 如 下 : 


S$(document).ready(functionO{ 
$("select").change(functionO{ 
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var value = $(this).valO); 
这 value — ""){ 
alert(" 请 选择 性 别 "); 
}else{ 
这 value 一 "nan"){ 
S$("#0").emptyO; 
S$("#o").append("<select id one><option value='pic/1 jpg> 头 像 1<loption><option 
value=pic/2jpg> 头 像 2</option><option value='pic/3.jpg> 头 像 3</option><option value='pic/4.jpg> 头 像 
4</option><option value='pic/9.jpg> 头 像 5</option></select>"); | 
$("#n").emptyO; 
$("#n").append("<img sre='pic/1.jpg'>"); 
$("#one").change(functionO{ 
Var va = $(this).val|; | 
S("#n").empty(); 
$("#n").append("<img src="+vat">"); 


»); | 

jelse{ | 

S$("#0").emptyO); | 

$("#0").append("<select id= one><option value= pic/5jpg> 头 像 1</option><option | 

value='pic/6jpg> 头 像 2</option><option value='pic/7jpg> 头 像 3</option><option value='pic/8.jpg> 头 像 | 
4</option><option value=pic/10.jpg> 头 像 5</option></select>"); | 


SCwnmempty0): 

SC"#n") append("<img sre=pic/5 jpe>"); | 
S$("#one").change(functionO { | 

Var va = $(this).val|:; | 

S$("#n").emptyO; | 

$("#n").append("<img sre="+vat+">"); | 

六 7: | 

} | 

} | 

有 | 
DD | 
实例 059 ”日 期 选择 器 

( 实例 位 置 配套 资源 \SL\04\059 ) | 


基于 目前 日 期 型 数据 格式 有 多 种 ， 采 用 录入 方式 相对 来 说 比较 烦琐 ,而且 采用 这 种 方 | 
式 也 不 利于 日 期 格式 的 统一 ， 所 以 可 以 在 信息 录入 页 面 中 加 入 一 个 简单 的 日 期 选择 器 来 解 | 
决 上 述 问题 。 运 行 本 实例 ， 在 新 奥 家 电 连 锁 后 台 管理 系统 的 销售 查询 页 面 中 ， 单 击 “ 售 货 | 
日 期 ”文本 框 后 的 日 期 选择 图 标 ， 会 弹出 “日 期 选择 器 ”对 话 框 ， 选 择 售 货 日 期 的 起 始 日 | 
期 ， 单 击 “ 确 定 ” 按 扭 ， 即 可 成 功 地 将 选择 的 日 期 添加 到 对 应 的 日 期 文本 框 中 ， 运 行 结果 
如 图 4.15 所 示 。 
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和 人 


信贷 昌 期 : 从 Poi0335 国 到 克 '06 五 


EET EE EE 


EE mg ml 
E33 


图 4.15 日 期 选择 器 


具体 步骤 如 下 : 
(1) 在 父 窗口 中 创建 函数 open_day_from0 和 函数 open_day to0， 实 现 子 窗口 的 弹出 


和 父 窗口 与 子 窗口 之 间 的 信息 传递 ， 代 码 如 下 : 


<table width="250" height="25" border="0" align="center" cellpadding="0" cellspacing="0"> 
<form name="form2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="adddayO"></a></div></td> 
<td width="80"> 
<select name="n1"> 
<?php 
for($i=2005;$1<=2050;$i++) { 
?> 
<option value=<?php echo $1:?>><?php echo $i:2></option> 
<?php 
} 
?> 
</select> 
年 </td> 
<td width="64"><select name="y1"> 
<?php 
for($i=1;$i<=12;$i++) { 
?> 
<option value=<?php echo $1:?>><?php echo $i:?></option> 
<2php 
} 
> 
</select> 
月 </td> 
<td width="77"><select name="r1"> 
<?php 
for($i=1;$1<=31;$1++) { 
es 
<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
中 
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?> 
</select> 
日 <td> 
<td width="16"><div align="center"><a href="#" onClick="subdayO"></a></div></td> 
</t> 
</form> 
</table> 
<table width="250" height="20" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td bgcolor="#826650"><div align="center"><input type="button" onClick="close_ day0O" class= 
"buttoncss" value=" 确 定 "></div></td> 
</tr> 
</table> 


(2) 单 击 “ 确 定 ” 按 钮 ， 调 用 close_day0 函 数 实现 日 期 的 传 值 ， 代 码 如 下 : 


<script language="javascript"> 
function close_dayO{ 
window.returnValue=document.form?2.n1.value+"-"+document.form?2.yl1.value+"-"+document.form2.r 


1.value; 
Window.close0; 
} 
</script> 
技术 要 点 


由 于 日 期 为 连续 的 数字 ， 开 发 网 页 时 将 这 些 信息 一 个 接 一 个 地 写 在 <option> 与 
</option> 标 记 之 间 固 然 可 行 ， 但 这 会 降低 程序 开发 时 间 。 开 发 本 实例 时 ， 笔 者 将 在 下 拉 列 
表 框 中 显示 的 连续 数据 通过 PHP 的 循环 结构 显示 出 来 ,这样 更 灵活 方便 。 实现 该 过 程 的 代 
码 如 下 : 


<form name="form?2"> 
<tr bgcolor="#826650"> 
<td width="13"><div align="center"><a href="#" onClick="adddayO"></a></div></td> 
<td width="80"> 
<select name="n1"> 
<?php 
for($i=2005:$i<=2050:$i+H){f 
?> 
<option value=<?php echo $i:?>><?php echo $i:?></option> 
<?php 
} 
?> 
</select> 
年 </td> 
<td width="64"><select name="y1"> 
<2php 
for(G$i=1:9i<=12;$i+H){ 
2 
<option value=<?php echo $1:?>><?php echo $i:?></option> 
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</select> 


会 内 | 月 <htd> 
NA | <td width="77"><select name="r1"> 
| <2php 
for($i=1;$1<=31;$1H) { 
| ?> 


<option value=<?php echo $1:?>><?php echo $1;?></option> 
<2php 
</select> 
日 </td> 


<td width="16"><div align="center"><a href="#" onClick="subday0"></a></div></td> 
</t> 


</form> 


实例 060 在 页 面 右 下 角 弹 出 渐 显 的 广告 窗口 


( 实例 位 置 : 配套 资源 \SL\04\060 ) 


实例 说 明 


广告 作为 网 站 最 大 的 芹 利 手段 ， 任 何 网 站 都 不 可 能 将 其 省 略 。 那 么 ， 如 何 才能 使 网 站 
| 既 可 以 从 广告 中 获 利 ， 又 能 使 用 户 流畅 地 阅读 网 站 信息 呢 ? 本 实例 将 介绍 如 何 制作 一 个 从 
| 首页 右 下 角 弹 出 的 渐 显 广告 窗 体 ， 在 用 户 登录 网 站 时 自动 从 右 下 角 渐渐 弹出 ， 然 后 由 用 户 
| 手动 将 其 关闭 。 运 行 结果 如 图 4.16 所 示 。 


图 4.16 右 下 角 渐 显 广告 


| 实现 过 程 


| 本 实例 主要 应 用 window 对 象 的 open 方法 调用 打开 一 个 在 首页 右 下 角 弹 出 渐 显 的 广告 
| 窗口 ， 在 网 站 首页 中 添加 如 下 代码 : 
| <script language="javascript"> 

var newformW=300; 

var newformH=180; 
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function ppO{ 
Var T=window.screen.width-newformW: 
var L=window.screen.height+newformH; | 
Var name=window.open("advertise.htm","","width="+newformW+",height="+newformH+",top="+T+",; 
left="+L); | 
} 
ppO; 
</script> 


技术 要 点 

本 实例 主要 应 用 JavaScript 脚本 的 window 对 象 , window 对 象 主要 应 用 在 HIML 中 打 
开 窗 口 ， 应 用 极为 普遍 ， 但 也 有 一 些 缺 陷 。 用 户 浏览 器 决定 窗口 的 外 观 ， 设 计 者 左右 不 了 
其 窗口 的 大 小 及 样式 ,但 JavaScript 给 了 程序 这 种 控制 权 。 在 JavaScript 中 , 可 以 使 用 window 
对 象 来 实现 对 窗口 的 控制 。 


实例 061 树 形 导 航 菜单 | 
( 实例 位 置 配套 资源 \SL\04\061 视频 位 置 配套 资源 \SP\04\061 ) 

说 月 
树 形 结构 能 够 以 层次 形式 展示 信息 , 用 它 
来 描述 具有 上 下 级 关系 的 内 容 再 恰当 不 过 了 。 


本 实例 利用 菜单 的 树 形 结构 来 描述 企业 人 事 © ana 
组 织 架 构 ， 效 果 如 图 4.17 所 示 。 ie 


铭 客户 服务 部 门 ! 


实现 过 程 
具体 步骤 如 下 : 
(1) 使 用 Dreamweaver 创建 一 个 PHP 动态 页 ， 并 保存 为 “index.php” 文 件 。 | 
(2) 创建 一 个 表单 ， 在 表单 中 添加 一 个 2 行 1 列 的 表格 ， 在 表格 的 第 2 行 再 添加 一 | 
个 2 行 2 列 的 表格 。 表 格 的 第 一 列 用 于 显示 节点 前 的 图 标 ， 第 2 列 描述 节点 文本 。 实 例 主 
要 代码 如 下 : 
<form id="form!1" name="formml" method="post" action="" > 


<table width="372" border="]1" align="center"” bgcolor="#E6F2F2" bordercolor="#478D8D" 
style="border-style:none" cellspacing="0" > 


图 4.17 树 形 导 航 菜单 


<tr> | 
<td scope="col" align="center" style="border-bottom-style:none" > 人 事 组 织 架 构 </td> | 
</tr> ! 
<tr> | 
<td> | 
<table width="100%" border="0" cellpadding="0" cellspacing="0" align="left> | 

<2php /嵌入 PHP 脚本 | 
$xml file = simplexml load file("org.xml"); /从 XML 文件 中 加 载 节点 | 
foreach($xml file->children() as $node){ // 遍 历 根 节点 | 

“91s 人 


人 Pp 经 各 编程 265 例 


| 2 
| <tr> 
| <td width="38%" align="right"> /设置 节点 图 标 
| <img src="images/rootnode.gif" width="15" height="15" border="0" > </img> 
| </td> 
到 | <td width ="62%" left="0px" align="left" ><a href="#" onclick= "ShowNode(<?php 
| echo $node ?>)">&nbsp;&nbsp; 
<?php echo $node ?></a> /设置 节点 文本 
| </td> 
| </tr> 
| <tr> 
| <td width ="38%" align="center" > 
| </td> 
| <td width ="6290" > 
| <div id= <?php echo $node ?> style = "display:none" class="HideDiv" >// 定 
| BED 
| <table width="100%" border="0" cellpadding="0" cellspacing="0" align="left" > 
| <?php 
| foreach($node->children() as $value){ /遍历 子 节点 
| 9> 
| <tr> 
| <td width ="10%" align="right" > 
| <img src="images/childnode.gif" width="15" height="15" border= 
| "0" > <img> 
| </td> 
| <td width="90%" align="left" ><a href="#" >&nbsp;&nbsp;<?php 
| echo $value?></a> 
| </td> 
| </t> 
| <?php 
| } 
| vs 
| </table> 
| </div> 
| </td> 
| </t> 
| <2php 
} 
| 2> 
| </table> 
| </td> 
| </t> 
| </table> 
| <script language="javascript"> 
| function ShowNode(ParentID) { // 隐 藏 或 显示 子 节 点 
| var Div = ParentID; 
| if (Div.style.display 一 "none"){ 
| Div.style.display = "block"; // 显 示 DIV， 以 此 来 显示 子 节点 
| }else if (Div.style.display 一 "block"){ 
| Div.style.display = "none"; /隐藏 DIV， 间接 隐藏 子 节点 
J .92 
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} 
} 
</script> 
</form> 


(3) 人 事 组 织 的 架构 存储 于 XML 文件 org.xml 中 。 
技术 要 点 


本 实例 中 , 实现 菜单 的 树 形 显示 是 通过 <table> 结 合 DIV 实现 的 。 父 节点 利用 表格 来 显 
示 , 子 节点 利用 DIV 嵌 套 表格 来 实现 。 这 样 做 的 目的 是 容易 对 子 节点 的 显示 和 隐藏 进行 控 
制 。 例 如 ， 当 用 户 单 击 父 节点 时 ， 如 果子 节点 没有 展开 ,将 DIV 设置 为 可 见 就 可 以 显示 子 
节点 。 如 果子 节点 可 见 ， 将 DIV 设置 为 不 可 见 就 可 以 隐藏 子 节点 。 


实例 062 收缩 式 导 航 菜单 


( 实例 位 置 : 配套 资源 \SL\04\062 ) 


实例 说 明 | 

在 网 站 中 不 仅 可 以 设置 导航 条 ， 而且 还 可 以 设置 导航 菜单 。 由 于 菜单 内 容 比 较 多 ,在 同 
一 页 面 中 显示 会 比较 杂乱 , 所 以 目前 大 多 数 的 设计 者 都 采用 收缩 式 的 导航 菜单 。 运 行 本 实例 ， | 
当 浏览 者 单 击 “ 网 站 管理 ” 超 链 接 时 ， 在 其 下 方 将 弹出 导航 菜单 ， 如 图 4.18 所 示 ， 浏 览 者 | 
再 次 单 击 “ 网 站 管理 ” 超 链接 时 ， 导 航 菜单 又 收缩 回去 ， 页 面 中 不 再 显示 菜单 中 的 内 容 。 


op 
和 ai 区 间 S 
后 台 管理 首页 良 出 


后 台 管 理 首页 银 出 


系统 信息 
版 权 所 有 : 明日 科技 
技术 支持 : 明日 科技 


4.18 收缩 式 导 航 菜单 
实现 过 程 
具体 步骤 如 下 : 
(1) 显示 菜单 的 自 定 义 函 数 ， 代 码 如 下 : 
<script language=javascript> 
function show(obj,maxg,obj2){ 
if(obj.style.pixelHeight<maxg) { | 

。93 。 


(有 ip 组 由 编程 265 例 


Dm 
obj.style.pixelHeight+=maxg/10; 
obi.filters.alpha.opacity+=20; 
obj2.background="images/title_ hide.gif"; 
if(obj.style.pixelHeight—maxg/10) 
obj.style.display='block’; 

myObj=obj; 

mymaxg—maxg; 

myObj2=0bj2; 
setTimeout('show(myObj,mymaxg,myObi2)','5"); 
} 


} 
</script> 


(2) 隐藏 菜单 的 自 定义 函数 ， 代 码 如 下 : 


<script language=javascript> 
function hide(obj,maxg,obj2){ 
if(obj.style.pixelHeight>0) { 
if(obj.style.pixelHeight—maxg/5) 
obj.style.display='none'; 
obj.style.pixelHeight-=maxg/5; 
obj.filters.alpha.opacity-=10; 
obj2.background="images/title_show.gif"; 
myObj=obj; 
mymaxg—=maxg 
myObj2=obj2; 
setTimeout('hide(myObj,mymaxg,myObj2)'",'5"); 
} 
else 
if(whichContinue) 
whichContinue.clickO; 


} 
</script> 


(3) 单 击 菜单 上 的 文字 超 链 接 时 ， 显 示 当 前 菜单 ， 并 隐藏 前 一 个 菜单 ， 代 码 如 下 : 
‘<script language=javascript> 
function chang(obj,maxg,obj2){ 
if(obj.style.pixelHeight) { 
hide(obj,maxg,obj2); 


nopen="; 
whichcontinue="; 


} 
else 
if(nopen){ 
whichContinue=obj2; 
Dopen.clickO: 
} 
else{ 
show(obj.maxg,obj2): 
nopen=obj2; 


日 
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whichContinue="; 

} 

1 
</script> | 
(4) 在 表格 的 相关 鼠标 事件 中 调用 自 定义 的 方法 和 属性 来 改变 收缩 菜单 的 显示 和 隐 | 
藏 ， 代 码 如 下 : | 
<ID class=list title id-listl onmouseover="this.typename="list title2'’;" onclick=chang(menul, | 
60,list1); - onmouseout="this.typename='list title':" background="images/title hide.gif' height=25><SPAN> | 
网 站 管理 </SPAN> </TD> | 
技术 要 点 


本 实例 主要 是 利用 显示 隐 荐 表格 来 实现 收缩 式 导 航 菜单 的 功能 。 单 击 导航 超 链接 ， 显 | 
示 当 前 菜单 的 内 容 ， 隐 藏 上 一 个 显示 的 菜单 。 在 隐藏 菜单 时 ， 让 其 有 规律 地 隐藏 ， 进 而 实 | 
现 动画 的 效果 。 | 


实例 063 ”控制 登录 用 户 的 过 期 时 间 


( 实例 位 置 : 配套 资源 \SL\04\063 ) 


实例 说 明 | 

Cookie 是 在 HITP 协议 下 , 将 服务 器 传递 给 浏览 器 的 少量 数据 保存 到 用 户 浏览 器 的 一 
种 方式 。 通 过 这 种 方式 ， 即 使 在 浏览 器 被 关闭 和 连接 中 断 的 情况 下 ， 用 户 仍然 可 以 维护 状 | 
态 数 据 。 本 实例 在 创建 和 读 取 Cookie 的 同时 ， 设 置 Cookie 的 生命 周期 ， 实 现 控制 登录 用 | 
户 的 过 期 时 间 。 运 行 结果 如 图 4.19 所 示 。 | 


- 一 一 


图 4.19 控制 登录 用 户 的 过 期 时 间 


实 现 过程 

具体 步骤 如 下 : 

(1) 创建 index php 文件 , 并 编写 用 户 登录 页 面 , 将 用 户 登录 信息 提交 到 index_ okphp | 
文件 。 
(2) 创建 index_ok php 文件 ， 获 取 表 单 提交 的 用 户 登录 信息 ， 并 判断 登录 的 用 户 名 | 
和 密码 是 否 正确 。 如 果 正 确 ， 则 将 用 户 名 和 密码 赋 给 指定 的 Cookie 变量 ， 并 设置 Cookie | 
的 过 期 时 间 ， 然 后 跳 转 到 cookie php 页 面 ， 否 则 ， 直 接 给 出 提示 信息 ， 并 重新 跳 转 到 登录 | 
页 。 其 关键 代码 如 下 ; 


。95 。 
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j CD 
eh、 
| <2php 
这 $ POST['user]—"mr" && $ POST['pass']—"mrsoft'"){ /判断 用 户 名 和 密码 是 否 正确 
setCookie("user",$ POST[user],time0+60)or die(" 禁 止 cookie"); ”// 创 建 Cookie 
setCookie("pass",$ POST[pass']time0+60)or die(" 禁 止 cookie");”// 创 建 Cookie 
echo "<script>alert( 登 录 成 功 ! ); window.location.hre 伍 'cookie.php';</script>"; 
}else{ 
echo "<script>alert( 用 户 名 或 者 密码 不 正确 ! 0; windowlocation href='index.php':</script>"; 


> 


| (3) 创建 cookie.php 文件 ， 并 判断 Cookie 变量 的 值 是 否 存 在 。 如 果 存 在 ， 则 输出 本 
| 页 内 容 ， 和 否则 ， 给 出 提示 信息 并 跳 转 到 登录 页 面 。 其 关键 代码 如 下 : 


<?php 
if($ COOKIE['user]—"mr" && $_Cookie['pass']—"mrsoft"){ 
echo "欢迎 光临 ! "; 

}else{ 
| echo "<script>alert(Cookie 已 经 过 期 ， 请 重新 登录 ) window.location.href='index.php'; 
| </script>"; 
| } 
> 
| 技术 要 点 


(1) setcookie() 函 数 : 设置 Cookie。 
bool setcookie ( string name [, string value [, int expire [, string path [, string domain [, int secure]]]]]); 
该 函数 的 参数 说 明 如 表 4.2 所 示 。 
表 4.2 setcookie() 函 数 的 参数 说 明 
参 数 举例 
. _ 可 以 通过 $_COOKIE['cookiename )] 调 用 变量 名 

BO I 为 cookiename 的 Cookie 
Cookie 变量 的 值 ， 该 值 保 存在 客户 端 ， | 可 以 通过 $_COOKIE['values '] 获 取 名 为 values 
不 能 用 来 保存 敏感 数据 的 值 
如 果 不 设置 Cookie 的 过 期 时 间 ， 那 么 Cookie 
将 永远 有 效 ， 除 非 手动 将 其 删除 


如 果 该 参数 设置 为 “/”， 则 它 就 在 整个 domain 

path Cookie 在 服务 器 端的 有 效 路 径 内 有 效 ， 如 果 设 置 为 “/5.1”， 它 就 在 domain 

下 的 /5.1 目录 及 子 目 录 内 有 效 。 默 认 是 当前 目录 

如 果 要 使 Cookie 在 mrbccd.cn 域名 下 的 所 有 子 

域 都 有 效 ， 应 该 设置 为 mrbccd.cn 

如 果 值 为 1, 则 Cookie 只 能 在 HTTPS 连接 上 有 

效 ; 如 果 值 为 默认 值 0， 则 Cookie 在 HITP 和 

HTTPS 连接 上 均 有 效 

(2) $ COOKIE: 经 由 HTTP Cookies 方法 提交 至 脚本 的 变量 ， 用 于 获取 Cookie 变量 
。96 。 


value 


| Cookie 的 过 期 时 间 ，expire 是 标准 的 
expire UNIX 时 间 标 记 ， 可 以 用 time0 函 数 或 
mktimeO 函 数 获取 ， 单 位 为 秒 


domain Cookie 有 效 的 域名 


指明 Cookie 是 否 仅 通过 安全 的 HITPS， 
值 为 0 或 1 


secure 
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的 值 。 


实例 064 单 点 登录 | 
( 实例 位 置 : 配套 资源 \SL\04\064 ) 中 - 
实例 说 明 
运行 本 实例 ， 如 果 是 第 一 次 登录 ， 那 么 将 进入 到 登录 页 面 ， 登 录 成 功 后 将 进入 到 博客 
主页 ， 如 图 4.20 所 示 。 在 主页 面 可 以 单 击 博客 中 的 “我 的 论坛 ” 超 链接 ， 以 此 用 户 的 身份 | 


直接 进入 到 论坛 系统 主页 中 ， 如 图 4.21 所 示 。 同 样 也 可 以 单 击 论坛 系统 中 的 “博客 ” 跳 
转 到 博客 的 页 面 中 。 | 


+ 首页 ， 避 好 > 入 用 


> RE 的 个 人 博客 


出 自 《出 窗 小 记 】 里 面 有 这 痒 一 个 对 联 : 完 于 不 称 ， 拓 旋 莉 花 开花 各 ; 去 多 无 总 ,各 天 底 云 关 云 好 。 这 名 i 汤 尖 窟 思 是 说， 为 人 记事 能 视 计 后 加 
rer ee hoe hire hr ee et yee | 
不遇 直 步 ， 而 人 的 久 而 却 更 全 ， 搬 放 适 发 于 度 ， 忆 臣民 而 序列 。 的 确 ， 社 会 正 不 晰 有 过 ,也 更 加 文明 了 ， 冰 而 广 机 广 会 的 一 个 外 本 茂 是 过 成 人 与 


SRP :mr 


天 以 力 所 、 管 0i 开 让 人 了 六 谍 ， 是 丰 、 成 妥 、 旬 和 让 人 节 再 、 束 下 ， 避 你 于、 弛 怕 、 革 人， 一 旦 所 从 听信 现 ， 一 所 交 愉 
所 哮 ， 一世 空 区 了 和 者 ， 外 全 请、 并 应 至 失 志 。 夫 东 是 一 各 :和 次 ， 昌 外 要 全 尖 交 区 亲 神 人 六 请 #; 失真 是 一 和 他 逢 是 失 | 


大 习作 ; 一 站 云 帮 云 更 下 大 大夫 忆 妇 人 的 党 在 志 型， 与 瑟 作 汪 的 下 以 站 在、 不 以 已 区 信 在 是 自生 网 工 ， 更 了 有 将 村 人 牧夫 公演 。 容 大 不 
你 ， 吉 入 无 和 议 起来 容 昌 ， 估 直 来 抒 二 分 图 于 - 


图 4.20 进入 博客 主页 面 | 
FANXING sx NE mE /A | 


~ 攻 硬 包 图 片 文件 充 
| 万 日 标 旺 [ss 吉 击 数 SS TW PTIAN 
[al 奈 冤 位 涯 衣 党 站 110 90 > 2 
] t 3 要 各 联系 方式 
口 。 所 间 人 置信 to an 4 ee 
[al 村 恶 位 置 大 如 处 0 a | 
EL a 硬 名 电子 图 节 
[a 稚 恶 位置 术 坦 处 Io 3330 sh 
日 状 杰 位 置 帮 慎 处 Ta0 3320 E73 
已 着 要 位 置 帮 导 处 
[al 其 机 位 置 帮 格 处 
[al 衬 要 位 置 训 豆 处 i110 3350 
其 有 2 页 , 当 章 是 逢 ] 页 FE IT 


图 4.21 进入 论坛 系统 主页 
实现 过 程 
这 里 以 博客 网 站 为 例 ， 讲 解 其 具体 的 操作 步骤 : | 
(1) 创建 index.php 页 面 ， 添 加 用 户 登录 的 表单 ， 将 登录 信息 提交 到 index_okphp 页 | 
面 中 。 在 index.php 页 面 中 首先 连接 数据 库 ， 然 后 判断 Cookie 的 值 是 否 为 空 ， 如 果 Cookie 
的 值 不 为 空 ， 并 且 在 指定 的 数据 表 中 存在 该 记录 ， 那 么 将 直接 进入 网 站 的 主页 ， 不 必 进 行 
登录 操作 ， 如果 Cookie 的 值 为 空 则 和 输出 网 站 登录 页 面 ， 并 且 删 除 指定 数据 表 中 已 经 过 期 | 
区 LU 
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的 用 户 登录 信息 ， 其 代码 请 参考 技术 要 点 的 内 容 。 

(2) 创建 index_ okphp 文件 ， 获 取 表 单 中 提交 的 登录 信息 ， 完 成 登录 操作 。 单 点 登 
录 的 第 一 个 关键 点 : 将 登录 成 功 的 用 户 名 和 Session ID 值 保存 到 Cookie 中 ,设置 Cookie 
过 期 时 间 为 1 小 时 ， 有 效 范围 是 服务 器 的 根 目录 。 单 点 登录 的 第 二 个 关键 点 : 将 登录 的 用 
户 名 和 Session ID 值 存储 到 一 个 数据 表 中 。 这 个 Cookie 值 和 数据 表 中 的 数据 是 验证 当前 用 
户 是 否 具有 单 点 登录 权限 的 唯一 依据 ， 代 码 如 下 : 


session start(); 


include_once 'conn/conn .php'; // 执 行 连接 数据 库 的 操作 
$name = addslashes($_ POST['name']):; // 获 取 用 户 名 
$pwd=$_POST[pwd]; /获取 密码 


if(!empty($name) and !empty($pwd)){ 


$sql = "select * from tb member Where name =".$name." and password =".$pwd.""; 


$num = $conne->getRowsNum($sq]): // 返 回 查询 结果 
$conne->close_Ist(); // 释 放 查 询 结果 
if($num — 0 or $num —"){ // 如 果 不 正确 
echo "<script>alert( 用 户 名 和 密码 不 正确 ! ); window.location href~'index.php';</script>"; 
}else{ // 如 果 正 确 ， 则 将 登录 用 户 名 数据 存储 到 Cookie 中 
$session id=session id(); // 获 取 SessionID 
setcookie("name", $name, time()+3600, "/"); // 创 建 Cookie 


setcookie("id", md5($session id), time0+3600, "/"); // 创 建 Cookie 


$sqls="insert into tb login(name,login id,datetime)values("".$name.",".md5($session id).", 


mmktimeO 


$nums = $conne->uidRst($sqls); // 返 回 查询 结果 
echo "<script>alert(' 登 录 成 功 ! '); window.location.href='default.php';</script>"; 


(3) 创建 default.php 网 站 主页 面 。 其 关键 就 是 根据 Cookie 值 和 指定 数据 表 中 存储 的 


数据 判断 当前 用 户 是 否 具有 访问 主页 的 权限 。 如 果 有 ， 则 输出 网 站 主页 的 内 容 ， 否 则 ， 将 
跳 转 到 登录 页 面 。 具 体 代码 如 下 。 


lid: 


if($_COOKIE[name]!="" and $ COOKIE[id]!=""){ 


include_once 'conn/conn.php'; // 执 行 连接 数据 库 的 操作 
$sql = "select * from tb login where name =".$ COOKIE[name]." and login id=".$ COOKIE 
$num = $conne->getRowsNum($sq]): // 返 回 查 询 结 果 
$conne->close TstO: /关闭 数据 库 
这 $num — 0 or $num —"){ 
header("Location: index.php"); 
}else{ 
> 
/省 略 了 主页 面 代码 


} 
96s 


第 企 章 We6 技术 8 


jelse{ 
header("Location: index.php"): 
B 
Ve 


(4) 在 conn 文件 夹 下 创建 conn.php 文件 ， 实 现 连 接 数 据 库 的 操作 。 


本 实例 开发 了 一 个 博客 网 站 和 一 个 论坛 网 站 ， 通 过 Cookie 实现 单 点 登录 的 功能 ， 即 
无 论 在 博客 或 者 论坛 中 只 要 登录 后 , 这 个 用 户 名 在 一 定时 间 内 , 在 这 两 个 网 站 中 是 通用 的 。 | 
其 关键 就 是 对 Cookie 值 的 判断 , 如 果 Cookie 的 值 存在 并 且 与 数据 库 中 存储 的 值 相同 ， | 
那么 就 可 以 实现 不 同系 统 之 间 的 跳 转 , 否则 就 必须 先 登 录 , 然后 才 可 以 访问 系统 中 的 内 容 。 | 
其 关键 代码 如 下 : | 
<2php 
include_once 'conn/conn .php'; // 执 行 连接 数据 库 的 操作 
if($_COOKIE[name]!="" and $ COOKIE[id]!=""){ | 
$sql = "select * from tb login where name ="$ COOKIE[name].”" and login id ="$ COOKIE | 


Ed 
$num = $conne->getRowsNum($sq]):; // 返 回 查 询 结 果 
$conne->close Ist(); /关闭 数据 库 
if($num != 0 or $num !="){ // 如 果 在 数据 表 存在 该 记录 ， 则 直接 跳 转 到 登录 页 面 
header("Location: default.php"); 


}else{ // 否 则 输出 登录 页 面 的 内 容 
本 
<!-- 省 略 了 部 分 代码 --> 
<?php 
} 
}else{ 
// 清 除数 据 库 中 1 小 时 以 前 存储 的 用 户 登录 数据 〈 即 SESSION 过 期 以 后 的 数据 ) 
$datetimes=mktime()-3600: // 获 取 1 小 时 前 的 时 间 惟 
$sqls="delete from tb_ login where datetime<'".$datetimes."": // 执 行 删除 操作 
$nums = $conne->uidRst($sqls): // 返 回 查 询 结果 
?> 
<!-- 省 略 了 部 分 代码 -> 
<2?php } ?> 


实例 065 统计 用 户 在 线 时 间 
( 实例 位 置 : 配套 资源 \SL\04\065 ) 
实例 说 明 
所 谓 用 户 在 线 时 间 就 是 当 用 户 登录 到 页 面 开 始 ， 到 关闭 浏览 器 结束 的 时 间 差 。 而 | 


Cookie 的 生命 周期 在 默认 情况 下 关闭 浏览 器 时 自动 删除 ， 这 非常 符合 在 线 统计 时 间 的 特 | 
点 ， 是 很 多 服务 类 网 站 优先 选择 的 统计 手段 。 | 


900s 


A 
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本 实例 通过 创建 Cookie， 保 存 用 户 登录 到 页 面 的 


时 间 惟 ， 在 用 户 单 击 “退出 按钮 时 ， 计算 用 户 在 线 在 线 对 间 ，00201243 秒 ! 
| 时 间 。 运 行 结果 如 图 4.22 所 示 。 Cr 
| 实现 过 程 
具体 步骤 如 下 : S 
(1) 沿用 实例 064 的 Forum 系统 ， 在 index.php 图 4.22 ”统计 用 户 在 线 时 间 
文件 中 创建 Cookie， 存 储 用 户 的 登录 时 间 戳 。 其 关键 
代码 如 下 : 
<2php 
include_once 'conn/conn php': /执行 连接 数据 库 的 操作 
$str =timeg0: 
Setcookie(times',$stD; 


if($_COOKIE[name]!="" and $ COOKIE[id]!=""){ 
$sql = "select * from tb login where name =".$ COOKIE[name]." and login id=".$ COOKIE 


[idl"": 
$num = $conne->getRowsNum($sq]); // 返 回 查 询 结 果 
S$conne->close_rst(); // 关 闭 数 据 库 
if($num != 0 or $num !="){ 
header("Location: default.php"); 
}else{ 
> 


(2) 创建 mformation .php 文件 ， 用 系统 的 当前 时 间 戳 减 去 Cookie 中 存储 的 登录 时 间 
惟 ， 即 获取 到 系统 的 在 线 时 间 的 时 间 蕉 ， 并 通过 date0 函 数 对 这 个 时 间 戳 进行 格式 化 ， 输 
出 用 户 的 在 线 时 间 ， 同 时 输出 登录 用 户 的 卫 和 机 器 名 称 。 其 关键 代码 如 下 : 
<?php 
$string =time0-$ COOKIE['times']: 
echo "在 线 时 间 : "date("H:is"$string)." 秒 ! "."<br>"; 
echo "您 的 也 地 址 : "getenv(REMOTE ADDR)."<br>"; 
echo "您 的 机 器 名 称 : ".gethostbyaddr(getenv(REMOTE ADDRJ); 
?> 
技术 要 点 
本 实例 的 关键 点 是 通过 创建 Cookie 保存 用 户 登 录 到 页 面 的 时 间 戳 并 与 结束 时 间 戳 做 
减法 运算 。 
用 户 登 录 时 间 : 
$str = time(); 
setcookie('times', $str); 
用 户 退 出 时 间 : 
$string=time0-$_COOKIE[Ytimes']; 
echo "在 线 时 间 : "date("H:is"$string)." 秒 1 "."<br>"; 


os 
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实例 066 限制 用 户 访问 网 站 的 时 间 


( 实例 位 置 : 配套 资源 \SL\04\066 ) 


实例 说 明 


默认 情况 下 Cookie 生命 周期 是 以 关闭 浏览 器 为 基准 。 也 就 是 说 ， 如 果 用 户 不 关闭 浏 | 
览 器 ， 并 且 没有 对 Cookie 进行 设置 ，Cookie 永远 也 不 会 过 期 失效 。 假如 用 户 在 互联 网 发 
布 网 站 ， 有 成 百 上 千 的 用 户 浏览 这 个 网 站 ， 并 且 在 线 浏览 用 户 数量 一 直 增加 。 如 果 不 对 用 | 
户 访 问 网 站 的 时 间 进 行 限制 ， 结 果 只 能 是 服务 器 资源 耗 尽 ， 网 站 瘫痪 。 | 
本 实例 通过 设置 Cookie 限制 用 户 访问 网 站 的 时 间 , 运行 结果 如 图 4.23 和 图 4.24 所 示 。 | 


FANXING sx: 


~ 


py 
“= 您 访问 网 站 的 时 间 到 了 ! 
图 4.23 ”Cookie 未 失效 ,访问 网 站 图 4.24 Cookie 失效 
现 过 程 
具体 步骤 如 下 : 


(1) 创建 index.php 文件 。 首 先 ， 初 始 化 SESSION 变量 ， 获 取 Session ID。 然 后 ， 
通过 setcookie0) 函 数 创建 Cookie， 并 将 Session_ID 作为 Cookie 值 ， 同 时 设置 Cookie 的 有 | 
效 时 间 为 10 秒 。 

(2) 在 页 面 中 通过 判断 Cookie 变量 的 值 是 否 为 空 来 限制 用 户 访问 网 站 的 时 间 。 i 
键 代码 如 下 : 


<2php 
iftisset($_COOKIE['start' Dl| $ COOKIE['start']—$session id){ 


?> 
.….// 省 略 了 网 页 中 的 代码 


<?php 

}else{ 

echo "<hl style ='color:red; 人 > 您 访问 网 站 的 时 间 到 了 </h1>"; 
} 


> 


技术 要 点 


本 实例 的 关键 点 是 通过 setcookie0 函 数 创建 Cookie 并 设置 Cookie 的 有 效 时 间 。 然 后 ， | 
通过 判断 Cookie 变量 是 否 存 在 和 Cookie 变量 的 值 是 否 为 空 来 控制 访问 网 站 的 时 间 。 其 | 


0Ts 
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| 键 代码 如 下 : 
| <?php 
| Session start(); /初始 化 SESSION 变量 
| $session id=session id(); /获取 Session ID 
食 生 | | setcookie("start",$session jd.timeO+10); /定义 Cookie 变量 ， 设 置 Cookie 的 有 效 时间 是 10 秘 


实例 067 SESSION 更 换 聊天 室 界 面 


( 实例 位 置 : 配套 资源 \SL\O4\067 ) 


| 实例 说 明 

SESSION 可 以 实现 数据 在 页 面 之 间 的 传递 ,并 且 在 SESSION 的 生命 周期 中 一 直 有 效 。 
| 本 实例 中 将 运用 SESSION 的 这 个 特性 ， 编 写 一 个 简单 的 聊天 室 换 肤 功能 。 在 聊天 室 中 ， 
| 根据 提交 的 颜色 值 更 换 聊天 室 的 背景 颜色 。 其 运行 结果 如 图 4.25 所 示 。 


六 | 
| 面 - 


这 人 轩 天 宣 。 次 和 入。 主 这 旺旺 下 则 天 的 内 容 ， 多 电大 基站 各 天 室 约 如 则 ， 


不 要 在 如 天 室 中 传播 不 全 唐 的 和 符 法 9 内 容 ， 谢 谢 合 作 冰 景 颜色 
| 图 4.25 更 换 聊天 室 背 景 颜 色 
| 实现 过 程 
| 具体 步骤 如 下 ， 
| (1) 创建 index.php 文件 ， 并 设计 一 个 简单 的 聊天 室 页 面 。 在 聊天 室 的 log 中 插入 一 
| 个 颜色 选项 卡 图 片 ， 并 为 每 种 颜色 设置 矩形 热点 链接 ， 链 接 到 index.php 文件 。 同 时 ， 定 
| 义 超 链 接 参 数 col， 参 数值 是 热点 链接 对 应 的 颜色 值 。 
| (2) 在 index.php 文件 中 ， 获 取 超 链接 传递 的 参数 值 ， 并 将 其 赋 给 SESSION 变量 ， 
| 然后 根据 SESSION 变量 的 值 设置 页 面 中 body 标记 的 bgcolor 的 值 ， 完 成 聊天 室 背 景 颜色 
| 的 更 换 。index.php 的 关键 代码 如 下 : 


<2php 
$_SESSION[bgcolor]-$_GET['col]; /获取 超 链接 传递 的 参数 值 ， 并 赋 给 SESSION 变量 

?> 
! <body bgcolor="<?php if($_SESSION['bgcolor']==""){echo "white";}else{echo $_SESSION 
| [bgcolor]:}?>"> 
| /省 略 了 部 分 代码 

<map name="Map" id="Map"> 

<area shape="rect" coords="4,3,27,26" href="index.php?col=0066FF" /> 

<area shape="rect" coords="64,5,87,26" hre="index.php?col=00CCFF" /> 

<area shape="rect" coords="31,34,55,56" href="index.php?col=999900" /> 
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<area shape="rect" coords="218,64,237,85" href="index.php?col=CC9933" /> 
<area shape="rect" coords="184,33,209,55" href="index .php?col=CC6600" /> 
<area shape="rect" coords="214,7,237,28" href="index.php?col=3399FF" /> 
<area shape="rect" coords="8,63,27,87" href="index.php?col=996633" /> 
<area shape="rect" coords="65,61,88,87" href="index.php?col=99CC33" /> 
<area shape="rect" coords="152,61,177,87" href="index.php?col=CC3333" /> 
</map> 
</body> 
技术 要 点 | 
本 实例 中 ， 首 先 获取 超 链接 中 传递 的 参数 值 ， 然 后 将 参数 值 赋 给 指定 的 SESSION 变 | 
量 , 最 后 将 SESSION 变量 设置 为 页 面 背景 颜色 bgcolor 的 值 ， 进 而 实现 聊天 室 背 景 颜色 的 | 
更 换 。 其 关键 代码 如 下 : | 
<2php 


$_SESSION['bgcolor ]=$_GET['col]: // 将 超 链 接 传递 的 参数 值 赋 给 SESSION 变量 
We 


dy bgcolor="<?php if($_SESSION['bgcolor']=="") {echo "white";}else{echo $_SESSION | 
[bgcolor];}?>"> | 

在 body 标记 中 ， 通 过 站 语 句 判 断 SESSION 变量 的 值 。 如 果 值 为 空 ， 则 设置 bgcolor | 
的 值 为 “white”， 否则， 直接 将 SESSION 变量 作为 bgcolor 的 值 。 | 


实例 068 ”掌控 登录 用 户 的 权限 


( 实例 位 置 : 配套 资源 \SL\04\068 ) 


实例 说 明 | 

在 论坛 中 ， 如 果 是 管理 员 ， 则 可 以 发 布 公告 信息 ; 如 果 是 普通 用 户 ， 就 不 可 以 发 布 公 | 
告 信息 。 那 么 ， 程 序 中 是 如 何 对 登录 用 户 的 权限 进行 判断 的 呢 ? 这 就 是 我 们 在 本 实例 中 | 
将 要 向 大 家 介绍 的 技术 一 一 通过 SESSION 变量 掌控 登录 用 户 的 权限 。 如 果 是 管理 员 登 录 ，| 
则 可 以 添加 公告 信息 ; 如 果 是 普通 用 户 则 只 可 以 浏览 论坛 中 的 帖子 。 其 运行 结果 如 图 426 | 
和 图 4.27 所 示 。 | 


FANXING ms 


首页 1 注册 便 录 1 5 
ar 局 5 
FANXING -ss Hm (Hum pr 
首页 | 证 册 | 登录 | 论坛 | 留言 0 RR A 由 NN mm 
口 。 且 全 于 坟 于 涉 > a 
口 。 大 是 位 各 提 于 处 要 大 电子 图 书 
nr ge wens re 
POT 去 亚 
多 We ee | 口 5 处 ia aaa 
Na 
el 到 口 。 二 外 ia 2aa0 
2 FE 一 Ex 
图 4.26 管理 员 登 录 图 4.27 发 布 留言 


如 上 所 述 ， 以 管理 员 身 份 进 行 登录 ， 进 入 到 main php 主页 后 ， 可 以 单 击 “留言 ” 超 链 
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接 ， 发 布 留言 信息 ; 如果 是 以 普通 用 户 身份 登录 ， 那 么 在 main php 主页 中 ,“ 留 言 ” 超 链 


接 是 不 可 以 点 击 的， 因为 普通 用 户 不 具备 发 布 留言 的 权限 。 
| 实现 过 程 


| 具体 步骤 如 下 ; 

(1) 创建 ndex php 文件 ， 添 加 表单 ， 设 计 用 户 登 录 页 面 ， 并 获取 表单 提交 的 用 户 名 
| 和 密码 ， 在 本 页 中 对 用 户 提交 的 数据 进行 判断 。 首 先 ， 初 始 化 SESSION 变量 ， 判 断 用 户 
| 提交 的 值 是 否 为 室 ， 如 果 登 录用 户 是 管理 员 ， 则 为 SESSION 变量 type 赋值 为 0， 如 果 合 
| 录用 户 为 普通 用 户 ， 则 为 SESSION 变量 type 赋值 为 1。 其 关键 代码 如 下 ; 


<?php 
session start(); 
if($_POST['sub']=—true) { 
if($_POST['user]!="" && $ POST['pwd']!=""){ /判断 用 户 名 和 密码 是 否 为 空 
这 $_POST[user] 一 "mr' && $ POST[pwd] 一 "mrsoft){ /判断 是 否 为 管理 员 
$_SESSION['type]= 0: /为 SESSION 变量 赋值 为 0 
echo "<script>alert( 管 理 员 登 录 成 功 ! ); window.location href='main.php';</script>"; 
jelse{ 
$_SESSION['type]= 1: // 如 果 不 是 管理 员 , 为 SESSION 变量 赋值 为 1 
echo "<script>alert( 用 户 名 登录 成 功 ! "); window.location href='main.php':</script>"; 


b 
$_SESSION['user'] =$_POST[user]; /将 登录 用 户 名 存储 到 SESSION 变量 user 中 
$_SESSION['pwd'] =$_POST['pwd']; /将 登录 密码 存储 到 SESSION 变量 pwd 中 
}else{ 
echo "<script>alert( 用 户 名 和 密码 不 能 为 室 ! '); window.location.href~'index.php';</script>"; 
} 
} 


?> 
| (2) 创建 main php 文件 ， 并 编写 网 站 的 主页 面 。 首 先 初始 化 SESSION 变量 , 然后 根 
| 据 SESSION 变量 type 的 值 定义 页 面 的 输出 内 容 。 如 果 SESSION 变量 的 值 为 0， 则 说 明 登 
| 录用 户 是 管理 员 ， 那 么 具备 发 布 公告 的 权限 ; 如 果 SESSION 变量 的 值 为 1， 则 说 明 登 录用 户 
| 是 普通 用 户 ， 就 不 具体 发 布 公告 的 权限 ， 即 控制 发 布 公告 的 超 链接 不 输出 。 其 关键 代码 如 下 : 
| <2php 

session start(); // 初 始 化 SESSION 变量 


?> 
<2php 
if($_SESSION['type'] 一 "0"){// 根 据 SESSION 变量 type 的 值 决定 是 否 输出 发 布 公告 的 超 链接 
?> 
<area shape="rect" coords="330,64,385,100" hre 人 ="mes.php" 人 > 
<?php 
} 
?> 
(3) 创建 mesphp 文件 ， 编 写 发 布 公告 信息 的 页 面 ， 根 据 SESSION 变量 type 的 值 决 
| 定 用 户 是 否 具 有 访问 此 页 面 的 权限 。 
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技术 要 点 


(1) 应 用 SESSION， 首先 要 初始 化 SESSION 变量 ， 其 应 用 的 是 session_start0 函 数 ， 
语法 如 下 : | 


bool session start ( void ); | 
它 判断 是 否 有 一 个 会 话 ID 存在 。 如 果 不 存 在 ， 就 创建 一 个 ， 如 果 存 在 ， 则 将 这 个 已 | 
注册 的 会 话 变量 载 入 ， 以 供 使 用 。 | 
(2) 创建 SESSION 变量 ， 应 用 预定 义 变量 $_SESSION[]， 语 法 如 下 : 
$_SESSION["name"] = "value"; 
通过 预定 义 变量 $_SESSION 中 定义 SESSION 变量 “name ”为 设置 变量 的 名 称 , “value”| 
表示 设置 变量 的 值 。 | 


实例 069 屏蔽 页 面 刷新 对 计数 器 的 影响 


( 实例 位 置 : 配套 资源 \SL\04\069 视频 位 置 : 配套 资源 \SP\04\069 ) 


实例 说 明 | 
计数 器 用 来 统计 一 个 网 站 被 访问 的 次 数 ， 它 体现 了 一 个 网 站 的 受 关注 程度 。 本 实例 将 
向 大 家 介绍 如 何 制作 计数 器 ， 以 及 如 何 屏 蔽 刷新 页 面 对 计 数 器 的 影响 。 在 本 实例 中 ， 当 用 | 
户 访 问 时 计数 器 的 值 会 增加 一 次 ， 但 是 无 论 如 何 刷新 页 面 ， 计 数 器 的 值 都 不 会 再 次 增加 ， 
只 有 重新 打开 页 面 ， 计 数 器 的 值 才 会 发 生变 化 。 本 实例 的 运行 结果 如 图 4.28 所 示 。 


加 站 的 访问 重 : 73 


图 4.28 ”屏蔽 页 面 刷新 对 计数 器 的 影响 
现 过 程 


具体 步骤 如 下 : | 

(1) 创建 index.php 文件 ， 并 输出 网 页 当前 的 访问 量 。 首 先 ， 初 始 化 一 个 SESSION | 
变量 。 然 后 ， 判 断 SESSION 变量 的 值 是 否 为 空 ， 如 果 值 为 空 ， 则 打开 指定 的 文本 文件 ， | 
读 取 其 中 存储 的 数据 ， 并 且 将 文本 文件 中 的 数据 值 增加 1， 同 时 将 新 的 数据 写 入 到 文本 文 | 
件 中 ， 关 闭 文 件 。 最 后 ， 为 SESSION 变量 赋值 为 1。 其 关键 代码 如 下 : | 
<2php session start0: | 
这 $_SESSION[temp] 一 ""){V/ 判 断 $_ SESSION[temp] 一 "的 值 是 否 为 室 ， 其 中 的 temp 为 自 定义 的 | 


变量 
if(($fp=fopen("counter.txt","r"))=—false){ 
echo "打开 文件 失败 1"; 
jelse{ 
$counter=fgets($fp.1024); // 读 取 文 件 中 数据 
fclose($fp); // 关 闭 文 本 文件 
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$counter++; 1/ 计数 器 增加 1 
$fp=fopen("countertxt","w"); 。“”// 以 写 的 方式 打开 文本 文件 <!----> 
fputs($fp,$counter): // 将 新 的 统计 数据 增加 1 
7 felose($fp): /关闭 文件 
2 
S| $_SESSION[temp]=1; // 登 录 以 后 ，$_SESSION[temp] 的 值 不 为 定 ， 给 $_SESSION[temp] 赋 一 个 
”ov 人 
| > 
(2) 在 index.php 文件 中 ， 创 建 img 标签 ， 并 在 src 属性 中 调用 gdl.php 文件 ， 完 成 


| 网 站 访问 量 的 输出 。 

| (3) 创建 gdl.php 文件 ， 通 过 文件 系统 函数 读 取 存储 在 countertxt 中 的 网 站 访问 量 的 
| 数据， 并 通过 GD2 函数 输出 网 站 访问 量 的 数据 。 

| 技术 要 点 

| SESSION 变量 控制 重复 计数 的 原理 如 下 : 在 当前 页 被 访问 时 ， 初 始 化 一 个 SESSION 变 
| 量 , 判断 SESSION 变量 的 值 是 否 为 室 。 如 果 为 空 , 则 将 计数 器 的 值 增加 1, 并 且 为 SESSION 
| 变量 赋值 为 1。 此 时 , 在 当前 页 中 SESSION 变量 的 值 已 经 不 为 空 , 无 论 如 何 刷新 , SESSION 
| 变量 的 值 都 不 会 改变 ， 计 数 器 的 值 也 不 会 增加 。 


实例 070 SESSION 购物 车 


( 实例 位 置 配套 资源 \SL\04\070 视频 位 置 : 配套 资源 \SP\04\070 ) 


| 购物 车 是 在 网 上 购物 时 使 用 的 一 个 临时 存储 商品 的 “车 辆 ” 购物 车 能 为 用 户 在 网 上 
| 购物 提供 很 大 的 方便 ， 不 用 担心 一 次 购买 多 个 商品 时 要 进行 多 次 提交 结算 的 操作 ， 可 以 将 
| 所 购 商 品 放 入 购物 车 中 ， 等 选 购 完 所 有 商品 之 后 ， 一 起 进行 结算 。 在 本 实例 中 ， 将 介绍 
| SESSION 购物 车 的 实现 方法 ， 其 运行 结果 如 图 4.29 所 示 。 


商品 5 称 | 单价 (元 ) | 
相 扎 
手机 


<< 继 和 购买 清 宝 购 风车 >> 


图 4.29 SESSION 购物 车 


| 实现 过 程 
应 用 SESSION 技术 开发 购物 车 ， 其 具体 步骤 如 下 : 
(1) 创建 index.php 页 面 ， 实 现 商 品 展示 功能 。 设 计 原 理 是 : 从 数据 库 中 读 取 商 品 信 
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息 , 将 商品 信息 在 页 面 中 进行 分 栏 、 分 页 显示 , 并 为 商品 设置 购买 和 查看 购物 车 的 超 链 接 ， 
运行 结果 如 图 4.30 所 示 。 | 


商品 4 个 每 页 3 个 第 1 页 共 2 页 下 页 上 一 页 下 一 页 尾 页 


图 4.30 购物 车 商品 展示 页 面 


(2) 创建 by_commodity.php 文件 ， 实 现 购买 功能 ， 即 向 购物 车 中 添加 商品 。 首 先 创 | 
建 一 个 购物 车 ， 然 后 判断 购物 车 中 是 否 为 空 。 如 果 为 空 ， 则 将 商品 展示 页 中 “购买 ” 超 链 | 
接 传递 的 商品 ID 〈$_GET[id]) 和 数量 添加 到 购物 车 中 ;如 果 不 为 室 ， 则 判断 添加 商品 的 | 
ID 是 否 在 购物 车 中 已 经 存在 ， 如 果 存 在 则 不 能 重复 添加 ， 反 之 则 将 商品 卫 添加 到 购物 车 | 
中 ， 最 后 跳 转 到 shopping.php 购物 车 页 面 。 其 代码 如 下 : | 


<2?php 
session start(); // 初 始 化 SESSION 变量 
header ( "Content-type: text/html:; charset=UTF-8" ); /设置 文件 编码 格式 


if($_SESSION["goodsid"]=—"" && $ SESSION["goodsnum"] 一 "){U/ 判 断 SESSION 变量 是 和 否 为 空 | 
$_SESSION["goodsid"]=$_GET["id"]."@";/ 如 果 SESSION 变量 为 空 ， 则 为 其 赋值 为 商品 的 | 
ID， 并 以 @ 分 隔 | 
$_SESSION["goodsnum"]="1@": /如 果 SESSION 变量 为 空 ， 则 为 其 赋值 为 1, 并 以 @ 分 隔 | 

jelsef /如 果 SESSION 变量 不 为 空 | 
$array=explode("(@",$_SESSION["goodsid"]); / 则 以 @ 为 分 隔 符 , 将 SESSION 变量 中 的 数据 | 


写 入 到 数组 中 
这 in_array($_GET["id"],$array)){ // 如 果 判 读数 组 中 是 否 存 在 指定 的 了 
echo "<script>alert(' 该 商品 已 经 被 放 入 购物 车 ! '"):history.backO;</script>"; 
exit; 


/如 果 数 组 中 不 存在 指定 的 ID， 则 说 明 该 商品 还 没有 放 入 购物 车 中 


$_SESSION["goodsid"].=$_GET["id"]."@"; // 将 该 商品 添加 到 购物 车 中 
$_SESSION["goodsnum"].="1@"; // 更 改 商 品 数量 

} 

echo "<script>window.location.href='shopping_car.php';</script>"; 

> 


(3) 创建 shopping.php 购物 车 页 面 ， 对 购买 商品 进行 统计 ， 包 括 购买 数量 、 每 种 商 | 
品 的 金额 和 总 金额 ,并且 实现 删除 购物 车 中 商品 、 更 改 购物 车 中 商品 数量 以 及 清空 购物 车 | 
的 功能 ， 同 时 设置 “继续 购买 ”的 超 链接 。 其 代码 请 参考 本 书 配套 资源 。 | 
(4) 创建 change_commodity_counts.php 文件 ， 实 现 更 改 购物 车 中 商品 数量 的 功能 。 | 
首先 获取 shopping.php 页 面 表单 中 提交 的 商品 数量 和 商品 ID, 然后 通过 正则 表达 式 验证 商 | 
品 数量 是 否 为 正 整 数 ， 最 后 根据 商品 ID 找到 指定 的 商品 ， 更 改 商品 数量 ， 并 返回 到 购物 | 
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车 页 面 。 其 代码 如 下 : 


<?php 
session start(); 
header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 


$id=$ POST["id"]; /获取 商品 这 
$num=$ POST["goodsnum"]; // 获 取 商 品 数量 
S$preg="/^[0-9]*[0-9]$I^[0-9]*[0-9]8/"; // 编 写 正则 表达 式 
if($num—""){ // 判 断 提交 的 值 是 否 为 空 
echo "<script>alert( 数 量 不 能 为 空 !):historybackO:</script>"; 
exit; 
jelse if(!preg_match($preg,$num,$str)){ /判断 提交 的 数据 是 否 为 正 整数 
echo "<script>alert(' 数 量 只 能 为 正 整 数 !):history.backO:</scripf>"; 
exit; 
} 


S$arrayid=explode("@",$_SESSION["goodsid"]); 
$arraynum=explode("@",$_ SESSION["goodsnum'"]); 
$key=array_search($id,$arrayid): /在 数组 中 搜索 给 定 的 值 ， 如 果 成 功 则 返回 相应 的 键 名 
$arraynum[$key]=$num; /更改 商品 数量 
$_SESSION["goodsnum"]=implode("(@",$arraynum); /更 改 商 品 数量 
echo "<script>window.location.href='shopping_car.php';</script>"; 
> 
(5) 创建 delete_commodity.php 文件 ， 删 除 购物 车 中 指定 的 商品 。 首 先 获取 超 链接 中 
传递 的 商品 ID， 然 后 将 SESSION 中 的 字符 串 数据 转换 成 数组 ， 并 根据 商品 ID 获取 指定 
要 删除 的 商品 的 键 名 , 最 后 根据 键 名 为 指定 的 数组 赋 空 值 , 并 重新 将 数组 添加 到 购物 车 中 。 
具体 代码 请 参考 本 书 配套 资源 。 
(6) 创建 clear_ shopping carphp 文件 ， 清 空 购物 车 ， 即 将 SESSION 变量 $_ SESSION 
["goodsid"q] 和 $_SESSION["goodsnum"] 赋 值 为 宝 。 其 代码 如 下 : 


<?php 
Session start(): /初始 化 SESSION 变量 
header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 
$_SESSION["goodsid"]=""; /为 购物 车 的 ID 赋值 为 空 
$_SESSION["goodsnum"]=""; /为 购物 车 数量 赋值 为 空 
echo "<script>window.location.href='shopping_car.php';</script>":// 完 成 清空 操作 ， 跳 转 到 购物 页 面 
?> 

技术 要 点 


SESSION 购物 车 ， 顾 名 思 义 ， 其 主要 就 是 应 用 SESSION 变量 来 实现 的 。 而 所 谓 的 购 
物 车 ， 就 是 通过 $_ SESSION[] 创 建 的 两 个 SESSION 变量 : 其 中 goodsid 存储 商品 的 ID， 
goodsnum 存储 商品 的 数量 。 

购物 车 的 操作 流程 : 首先， 登录 到 网 站 中 浏览 商品 。 然 后 ， 购 买 指定 的 商品 ， 进 入 到 
购物 车 页 面 中 ， 可 以 实现 很 多 操作 ， 包 括 更 改 商品 数量 、 删 除 商品 、 清 空 购物 车 、 继 续 购 
物 等 。 最后， 填写 收 货 人 信息 ， 生 成 订单 ， 完 成 订单 打印 、 预 览 ， 提 交 订单 等 操作 。 其 操 
作 流 程 如 图 4.31 所 示 。 
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加 到 购物 车 | jy 车 
hn 
查看 购物 车 内 商品 


图 4.31 购物 车 操作 流程 


实例 071 清理 SESSION 缓存 提 高 网 站 访问 的 效率 
(实例 位 置 : 配套 资源 \SL\04\071 ) 
实例 说 明 


SESSION 缓存 将 网 页 中 的 内 容 临时 存储 到 客户 端 下 的 Temporary Intemet Files 文件 夹 | 
下 。 当 网 页 第 一 次 被 浏览 后 ， 页 面 的 部 分 内 容 在 规 | 


定 的 时 间 内 就 被 临时 存储 在 客户 端的 临时 文件 夹 清理 SESSION 缓存 
中 。 这 样 ， 下 次 访问 这 个 页 面 时 ， 就 可 以 直接 读 取 i 
缓存 中 的 内 容 ， 从 而 提高 网 站 的 浏览 效率 。 但 是 ， A 


如 果 不 对 SESSION 缓存 做 定期 处 理 的 话 ， 也 会 给 服 
务 器 带 来 压力 。 在 本 实例 中 ， 将 讲解 SESSION 缓存 


的 运用 和 清理 的 方法 。 其 运行 结果 如 图 4.32 所 示 。 图 432 输出 缓存 信息 
实现 过 程 
具体 步骤 如 下 : 


(1) 创建 index.php 文件 。 首 先 ， 定 义 SESSION 临时 缓存 文件 夹 路 径 并 开启 缓存 ， 
设置 缓存 时 间 为 30 分 钟 ， 启 用 SESSION， 设 置 SESSION 变量 。 其 代码 如 下 : 


<?php 
$path = /tmp/ /定义 缓存 文件 的 临时 存储 路 径 
session_ save_path($path): /设置 缓存 存储 路 径 
session_cache limiter('private"); /设置 缓存 方式 
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| $session_cache = session cache limiter0: ”// 开 启 缓存 


Session cache expire(30); // 定 义 缓存 时 间 
$session expire = session_cache expire(); ”// 设 置 缓 存 时 间 
session start(); /初始 化 SESSION 变量 


| $_SESSION['cache'] = $session cache: /为 SESSION 变量 赋值 
| $_SESSION['expire'] = $session expire; 


be | ?> 
| 
| 
| 
| 
| 
| 
| 
| 
| 


(2) 在 index.php 文件 中 ， 获 取 并 输出 缓存 中 存储 的 数据 ， 创 建 超 链接 ， 执 行 清理 组 
| 存 的 操作 。 清 理 方法 是 为 9$_ SESSION 赋 一 个 空 数组 值 ， 并 应 用 session_destroy0 函 数 彻底 
| 删除 会 话 。 其 关键 代码 如 下 : 
| <?php 
echo "<a href= "index.php?cache=0> 清 理 缓存 </a>"; 

这 $_GET[cache] =— "0"){ 


$_SESSION = arrayO; // 清 空 SESSION 

session_ destroy(); // 销 毁 会 话 

echo "<script>alert( 清 理 SESSION 缓存 成 功 ):location href-http://wwwmrbccd.com'</script>"; 
| ?> 
| 技术 要 点 


| 在 本 实例 中 ， 运 用 session_cache_limiter() 函 数 创建 缓存 ， 应 用 session_save_path() 函 数 
| 设置 缓存 文件 的 存储 路 径 ， 应 用 session_cache_expiry0 函 数 设置 缓存 时 间 。 
| session_cache_limiter() 函 数 用 于 创建 SESSION 缓存 。 其 语法 如 下 : 
string session_cache limiter ( [string cache limiter]) 
参数 cache_limiter 用 于 设置 缓存 的 方式 。 参 数值 的 说 明 如 表 4.3 所 示 。 
表 4.3 cache_limiter 参数 值 的 说 明 


不 设置 缓存 


私有 方式 
private nochache 私有 方式 ， 但 不 过 期 


ublic 公有 方式 


session_cache_expire () 函 数 用 于 设置 缓存 时 间 。 其 语法 如 下 : 


int session_cache_expire ( [int new_cache_expire]) 


| 参数 cache expire 为 可 选 参数 , 用 于 设置 SESSION 的 过 期 时 间 ， 单 位 为 分 钟 。 默认 过 
| 期 时 间 是 180 分 钟 ( 即 不 设置 参数 值 的 情况 下 )。 
| session_save_path0 函 数 用 于 取得 或 者 重新 配置 目前 SESSION 的 存储 路 径 。 其 语法 如 下 : 


string session_save_path([string path]) 


如 果 设置 参数 path， 表 示 重 新 设置 SESSION 的 存储 路 径 ， 如 果 不 设 置 参数 path， 表 
| 示 直 接 获 取 当 前 SESSION 的 存储 路 径 。 
| . 110 . 
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实例 072 限制 上 传 文件 的 大 小 


( 实例 位 置 : 配套 资源 \SL\04\072 视频 位 置 配套 资源 \SP\04\072 ) 


实例 说 明 

在 网 站 开发 的 过 程 中 , 为 了 确保 能 够 充 
分 地 利用 服务 器 的 空间 , 在 开发 上 传 功能 时 。 饮 一 个 此 srs 
最 好 能 够 对 上 传 文件 的 大 小 进行 控制 。 本 实 。 一 一 J 


各 在 上 信件 : evrr vor cin 区 


例 开发 的 上 传 功能 就 可 以 对 上 传 文件 的 大 LAA 

小 进行 限制 。 如 果 上 传 文件 超过 指定 的 范 [sx ss) 

围 , 将 给 出 提示 信息 ， 并 终止 上 传 。 运 行 效 ett Fett 

果 如 图 4.33 所 示 。 Copyrisht 1999.2010 吉林 作用 日 利 技 有 艰 公 司 

实现 过 程 图 433 限制 上 传 文件 的 大 小 
具体 步骤 如 下 ; 


(1) 创建 index.php 文件 。 | 
(2) 添加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 设置 enctype="multipart/form- | 
data"， 将 数据 提交 到 本 页 。 | 
(3) 通过 $_FILES 获取 上 传 文件 的 相关 信息 ， 通 过 move_upload_file0 函 数 完成 图 片 | 
上 传 。 有 具体 代码 如 下 : | 
<2php 
这 !empty($_FILES[up_picture][name])){ /判断 上 传 内 容 是 否 为 空 
if($_FILES['up_picture']['error']>0){ /判断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :"; 
Switch($_ FILES[up_picture']['error]){ 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break: 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 
Case 3: 
echo "上 传 文件 不 全 "; 
break; 
case 4: 
echo "没有 上 传 文件 "; 
break: 
} 
yelse{ 
if(!is_dir("./upfile/")){ // 判 断 指定 目录 是 否 存 在 
mkdir("./upfile/"): // 创 建 目 录 


} 
$path='./upfile/".time().strstr($_FILES['up_picture'][name"],""); // 定 义 文件 名 称 和 存储 位 置 
。111 。 四 
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公 % 
ifis_uploaded file($ FILES["up picture'"]["tmp name])){ // 是 否 是 HTTP POST 上 传 
这 !move uploaded file($ FILES["up picture']["tmp_name'"],$path)){ // 执 行 上 传 
echo "上 传 失 败 "; 
| jelse{ 
会 | echo "文件 "time0.$ FILES[up_picture][mame]." 上 传 成 功 ,大 小 为 : ".$_FILES 
~ |， [up pictue][size]; 

| } 

}else{ 


echo "上 传 文件 ".$_FILES[up_pictute][mame']." 不 合法 ! "; 


| 控制 上 传 文件 的 大 小 有 两 个 关键 点 : 第 一 点 是 PHP 的 配置 文件 php.ini 中 对 上 传 文件 
| 的 限制 如 果 上 传 文件 超过 它 指定 的 范围 ,那么 上 传 就 会 失败 ; 第 二 点 是 在 PHP 配置 文件 
| 允许 的 范围 内 ， 在 程序 中 对 上 传 文件 大 小 的 限制 。 

| (1) PHP 中 通过 php.ini 文件 对 上 传 文件 进行 限制 ， 包 括 : 是 否 支 持 上 传 、 上 传 文件 


| 在 php.ini 中 ， 定 义 到 File Uploads 项 ， 完 成 对 上 传 相关 选项 的 设置 。 上 传 相关 选项 的 
| 含义 如 下 : 
| 回 file uploads: 如 果 值 是 on， 说 明 服务 器 支持 文件 上 传 ， 如 果 为 off， 则 不 支持 。 
一 般 默认 是 支持 的 ， 这 个 不 用 修改 。 
回 upload tmp_dir: 上 传 文件 临时 目录 。 在 文件 被 成 功 上 传 之 前 ， 文 件 首先 存放 到 
服务 器 端的 临时 目录 中 。 多 数 使 用 系统 默认 目录 ， 但 是 也 可 以 自行 设置 。 
回 upload max filesize: 服务 器 允许 上 传 文件 的 最 大 值 ， 以 MB 为 单位 。 系 统 默认 
为 2MB， 如 果 网 站 需要 上 传 超过 2MB 的 数据 ， 那 么 就 要 修改 这 个 值 。 
| 上 述 是 php.ini 中 File_Uploads 项 中 与 上 传 相关 选项 参数 设置 的 说 明 。 除 了 File_Uploads 
| 项 中 的 内 容 外 ， 在 php.ini 中 还 有 其 他 几 个 选项 会 影响 到 文件 的 上 传 。 
| 加 ”max_execution_time: PHP 中 一 个 指令 所 能 执行 的 最 大 时 间 ， 单 位 是 秒 。 该 选项 
在 上 传 超大 文件 时 必须 修改 ， 不 然 ， 即 使 上 传 文件 在 服务 器 允许 的 范围 内 ， 但 是 
超过 了 指令 所 能 执行 的 最 大 时 间 ， 也 无 法 实现 上 传 。 
回 “memory limit:， PHP 中 一 个 指令 所 分 配 的 内 存 空间 ， 单 位 是 MB。 它 的 大 小 同样 
会 影响 到 超大 文件 的 上 传 。 
| (2) 在 客户 端 限制 上 传 文件 ， 应 用 的 是 form 表单 中 的 enctype 和 method 属性 ， 以 及 
| 隐藏 域 MAX FILE_SIZE。 
回 enctype="multipartform-data": 指定 表单 编码 数据 方式 。 
Imethod="post": 指定 数据 的 传输 方式 。 
<input type="hidden" name="MAX FILE SIZE" value="10000" />: 通过 隐藏 域 限 
制 上 传 文件 的 大 小 (单位 为 字 节 ), 该 值 不 能 超过 php.ini 配置 文件 中 upload_max_ 
filesize 选项 设置 的 值 。 它 不 能 完全 控制 上 传 文件 的 大 小 ， 只 是 可 以 避免 一 些 不 必 


了 。112 。 
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要 的 麻烦 。 切 记 ， 它 只 有 放置 在 file 文件 域 之 前 ， 才 能 有 效果 。 


上 述 两 种 判断 的 结果 都 可 以 通过 全 局 变量 $_FILES 的 返回 值 来 体现 。$ FILES 是 一 个 数 | 
组 ， 它 包含 所 有 上 传 的 文件 信息 。 下 面 介绍 一 下 $_FILES 数组 中 每 个 元 素 的 含义 ， 如 表 4.4 | 


所 示 。 


表 4.4 $_FILES 数组 中 元 素 
说 明 

存储 上 传 文件 的 文件 名 ， 如 texttxt、title jpg 等 
存储 文件 的 大 小 ， 单 位 为 字 节 
存储 文件 在 临时 目录 中 使 用 的 文件 名 。 文 件 在 上 传 时 ， 先 要 将 其 以 临 
时 文件 的 身份 保存 在 临时 目录 中 
存储 上 传 文件 的 MIME 类 型 ，MIME 类 型 规定 各 种 文件 格式 的 类 型 。 
每 种 MIME 类 型 都 是 由 “/” 分 隔 的 主 类 型 和 子 类 型 组 成 。 例 如 ， 
“image/gif”, 主 类 型 为 “图 像 ”, 子 类 型 为 GIF 格式 的 文件 “texthtml” 
代表 文本 的 HTML 文件 
存储 与 文件 上 传 相关 的 错误 代码 。 此 项 目 是 PHP 4.2.0 版 本 中 新 增 的 
内 容 ， 其 返回 值 有 5 种 ， 如 下 所 示 : 
0: 表示 没有 任何 错误 ， 文 件 上 传 成 功 
1: 表示 上 传 文件 的 大 小 超出 了 PHP 配置 文件 指令 upload_max filesize 
选项 限制 的 值 
2: 表示 上 传 文件 大 小 超出 了 HTML 表单 中 MAX_FILE_SIZE 选项 所 
指定 的 值 
3: 表示 文件 只 被 上 传 了 一 部 分 
4: 表示 没有 上 载 任何 文件 


元 素 名 
$ FILES[filename][namel 
$_FILES[filenamel][sizel 


$_FILES[filename][tmp_name] 


$_FILES[filenamej[type] 


$_FILES[filename][error] 


实例 073 限制 上 传 文件 的 类 型 


( 实例 位 置 : 配套 资源 \SL\04\073 ) 


实例 说 明 

在 开发 文件 上 传 功能 时 ， 不 仅 要 考虑 上 传 文件 的 大 小 ， 对 上 传 文件 的 类 型 也 要 考虑 。 
针对 不 同 的 需要 ， 对 上 传 文件 的 类 型 也 要 限制 ， 这 里 指 的 文件 类 型 可 以 通过 文件 的 扩展 名 
(例如 ，.txt、.php、.doc) 来 判断 。 
如 在 进行 文件 上 传 时 ， 在 涉及 到 文本 
说 明 性 的 文字 时 ， 最 好 将 上 传 的 文件 bd 个 后 人 nnnes 


限制 以 “.txt” 为 后 级 的 文本 格式 。 et 
运行 本 实例 , 单 击 图 中 的 “浏览 ” Ee 
EE ED EED 


按钮 ， 选 择 要 上 传 的 文件 (文件 不 是 


上 传 文件 类 型 不 王 确 ? 
以 “.txt” 为 扩展 名 )， 单 击 “ 提 交 ?” Copyright © 1999-2010 吉林 当 明 日 科技 有 限 公司 
按钮 程序 将 给 出 错误 提示 ， 如 图 4.34 图 434 限制 上 传 文件 的 类 型 


所 示 。 
“Ni3s 
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实现 过 程 


继续 使 用 实例 072 的 内 容 ， 在 此 基础 上 增加 对 上 传 文件 类 型 的 判断 ， 即 通过 预定 义 变 
量 $_FILES 获取 上 传 文件 的 名 称 ， 同 时 截取 上 传 文件 名 称 的 后 级 并 加 以 判断 。 如 果 后 级 部 
分 与 “.txt” 相 匹配 ， 则 执行 上 传 操作 ; 否则 ， 提 示 用 户 上 传 类 型 不 正确 。 增 加 的 关键 代码 
如 下 : 


<?php 


| 这 !empty($_FILES[up_picture][ name]){ /判断 上 传 内 容 是 否 为 空 

| $type=$_ FILES[mp_picture][mame']; /获取 上 传 文件 的 名 称 

| $types=strstr($type,'.); 1/ 截取 上 传 文件 的 后 缀 

| if($types—".txt"){ // 判 断 上 传 文件 的 后 级 是 否 符合 要 求 
| /省 略 了 部 分 代码 

| } 

| Jelse{ 

| echo "上 传 文件 ".$_FILES['"up_pictute']['name']." 类 型 不 正确 ! "; 
} 

) 

| ?> 

| 技术 要 点 


文件 的 上 传 和 对 大 小 的 限制 已 经 在 前 面 的 实例 中 讲解 过 ， 这 里 只 讲解 限制 上 传 文件 类 


型 的 关键 技术 。 首 先 通 过 预定 义 全 局 变量 $_FILES 中 的 $_FILES['files"][mame"] 获 取 上 传 文 
| 件 的 名 称 ， 然 后 应 用 strstrO 截 取 上 传 文件 名 称 的 后 绥 ， 最 后 判断 上 传 文件 的 后 绷 是 否 符合 


| 要 求 。 


| 始 到 strings 字符 串 结束 所 有 的 内 容 。 如 果 在 strings 中 没有 查找 到 needle， 该 函数 将 返回 


strstr() 函 数 的 语法 如 下 : 
string strstr(string strings, string needle); 
该 函数 用 于 在 字符 串 strings 中 查找 字符 串 needle 的 位 置 ， 并 返回 从 needle 字符 串 开 


| false。 


| 多 学 两 招 ， 


判断 上 传 文件 是 否 符合 多 种 类 型 中 的 一 种 ， 最 佳 的 方法 就 是 将 多 种 类 型 定义 到 一 


”组 中 ， 然 后 通过 for 循环 输出 数组 中 的 元 素 值 ， 将 输出 的 元 素 值 与 获取 的 文件 后 2 
| 较 ， 进 而 判断 其 是 否 符合 要 求 。 


实例 074 通过 链接 方式 下 载 


( 实例 位 置 : 配套 资源 \SL\04\074 ) 


”实例 说 明 


在 一 个 完整 的 网 站 中 ， 拥 有 文件 下 载 的 功能 能 够 给 网 站 带 来 更 多 的 访问 者 ， 增 加 网 站 
. 114 . 


的 访问 量 。 最 常用 的 文件 下 载 方式 就 是 通过 链 Ts rp 
接 下 载 。 在 本 实例 中 , 应 用 链接 方式 进行 下 载 ， 
当 单 击 “ 下 载 ” 文 字 的 超 链接 或 单 击 右键 “ 另 
存 为 ”时 ， 即 可 弹出 文件 下 载 的 对 话 框 ， 完 成 
下 载 操 作 。 其 运行 结果 如 图 4.35 所 示 。 
实现 过 程 
首先 创建 一 个 多 文件 上 传 页 面 mdex.php， 

然后 为 输出 的 图 片 名 称 创 建 超 链 接 。 当 用 户 在 
该 超 链 接 名 称 上 单 击 鼠标 右键 并 选择 “另存 | 
为 ”时 ， 即 可 弹出 文件 下 载 的 对 话 框 ， 选 择 完 路 径 后 单 击 “ 保 存 ” 按 钮 ， 完 成 图 片 的 下 载 | 
操作 。 其 关键 代码 如 下 : | 

<a href="<?php echo $myrow[file_test]:?>"> 

<?php echo $myrow[file name];?></a> 
技术 要 点 | 
本 实例 主要 通过 一 个 超 链 接 来 实现 文件 的 下 载 。 通 过 select 语句 从 数据 库 中 读 取 文件 
存储 的 路 径 ， 然 后 将 该 文件 作 一 个 超 链 接 ， 当 单 击 “ 下 载 ” 超 链接 时 ， 即 可 下 载 该 文件 。 | 


图 4.35 通过 链接 方式 下 载 


多 学 两 招 : 
如 果 是 压缩 的 文件 可 以 直接 下 载 ; 如 果 不 是 ， 则 需要 单 击 鼠 标 右键 ， 在 于 出 的 忆 抹 
单 中 选 树 “ 男 存 为 ”命令 ， 


实例 075 上 传 多 个 文件 到 服务 器 


( 实例 位 置 : 配套 资源 \SL\04\075 ) 


实例 说 明 
上 传 图 片 到 服务 器 是 程序 开发 过 程 中 
必 不 可 少 的 一 个 功能 。 它 不 但 可 以 达到 图 镶 一 个 此 人 srwms 
片 共享 的 目的 ， 而 且 可 以 提高 网 站 的 访问 == 
量 ， 丰 富 网 站 的 内 容 。 本 实例 讲解 如 何 通 
过 POST 方式 实现 多 图 片上 传 ， 运 行 结果 
如 图 4.36 所 示 。 
实现 过 程 图 4.36 POST 方式 多 图 片上 伟 
有 具体 步骤 如 下 : | 
(1) 创建 index.php 文件 。 添 加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 方法 ， 设 | 
置 enctype="multipart/form-data"， 将 数据 提交 到 index_ok.php 页 ， 完 成 多 个 文件 的 上 传 操 | 
。115 。 
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| Ca 
| 
| 作 。 其 关键 代码 如 下 : 


| <table width="750" border="0" cellspacing="0" cellpaddine="0"> 
| <form action="index_ok.html" method="post" enctype="multipart/form-data" name="forml"> 


<td height="25" align="right" class="STYLE1"> 内 容 2: </td> 
<td align="center"><input name="files[]" type="text" id="files[]" size="15"></td> 
<td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 
<t> 
<tr> 
<td colspan="3" align="center"> 
<input type="image" name="imageField" src="images/bg 09.jpg">&nbsp;&nbsp; 


# | <tr> 
天 给 | <td width="100" height="25" align="right" class="STYLE1"> 内 容 1: </td> 
| <td width="150" align="center"><input name="files[]" type="text” id="files[]" size= 
ey 
| <td align="left"><input name="picture[]" type="file" id="picture[]" size="30"></td> 
| </tr> 
! <tr> 


&nbsp;&nbsp; 
<input type="image" name="imageField2" src="images/bg_11.jpg"></td> 
</tr> 
</form> 
</table> 


(2) 在 index.php 文件 中 ， 连 接 数据 库 ， 读 取 数据 库 中 存储 的 数据 ， 实 现 上 传 文件 的 
分 页 输出 。 有 具体 代码 请 参考 配套 资源 中 的 内 容 。 

(3) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 将 多 个 文件 存储 到 服务 器 中 ， 
并 将 文件 的 名 称 和 存储 路 径 存 储 到 数据 库 中 。 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html; charset=UTF-8" ); /设置 文件 的 编码 格式 
include "conn/conn.php": /包含 数据 库 链 接 文件 


这 ($_ POST ["files"] (="") { 
这 (Lis_dir( "upfile" )) { 


mkdir ( "./upfile" ): // 创 建 上 传 文件 的 存储 文件 夹 
$data = date ( "Y-m-d H:m:s" ); // 定 义 时 间 
| function check($var) { /验证 数组 的 返回 值 是 否 为 空 
| return ($var (= ""); // 如 果 不 为 空 ， 则 返回 数组 元 素 
| } 
| Sfiles = array_filter ( $_POST ["files"], "check" ): // 去 除数 组 中 的 空 值 
| S$array = array_filter ( $_FILES ["picture"] ["name"], "check" ); // 去 除数 组 中 的 空 值 
foreach ( $array as $key => $value ) { /循环 读 取 数 组 中 的 数据 


| $path ="upfile/ . time 0 . Skey . strtolower ( strstr ( $value, "…" ) ); /定义 上 传 文件 的 存储 位 置 

| move_ Uploaded file($_ FILES ["picture"] ["tmp_name"] [$key], $path ); /执行 上 传 操 作 
$query = "insert into tb_ up_file (file testdata.file name) values (‘$path','$data','$files[$key])"; 
$result = mysql query ( $query ); 

} 
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echo "<script>alert( 图 片上 传 成 功 "); window.location.href='index.html';</script>"; 
| 
?> | 
技术 要 点 会 内 
多 文件 上 传 的 关键 是 如 何 定义 上 传 文件 元 素 的 名 称 ， 以 及 如 何 判断 上 传 文件 的 数量 。 ~ 
在 本 实例 中 ， 以 数组 的 形式 定义 上 传 文件 的 名 称 上 传 文件 的 名 称 是 “files[]”)。 为 了 达 
到 可 以 上 传 任意 数量 图 片 (4 个 图 片 以 内 ) 的 目的 ， 在 对 上 传 文件 进行 处 理 的 过 程 中 ， 应 | 
用 array_filter0) 函 数 和 回调 函数 去 除数 组 中 的 空 元 素 。 | 
array_filter0) 函 数 ， 表 示 用 回调 函数 过 滤 数 组 中 的 单元 ， 语 法 如 下 : 
array array_filter ( array input [, callback callback] ) 


array_filter0 函 数 依次 将 input 数组 中 的 每 个 值 传 递 到 callback 函数 。 如 果 callback 函数 | 
返回 tue， 则 input 数组 的 当前 值 会 被 包含 在 返回 的 结果 数组 中 ， 并 且 数 组 的 键 名 保持 不 变 。 | 
本 实例 中 定义 的 回调 函数 是 check0, 用 于 验证 数组 中 的 返回 值 是 否 为 空 。 其 语法 如 下 : | 
fmetion check(8var) { /验证 数组 的 返回 值 是否 为 空 

Teturn ($var (= ""); 


: 


指点 迷津: 
在 回调 函数 中 ， 不 要 对 数组 进行 修改 操作 ， 例 如 ， 增 加 或 者 删除 数组 中 的 元 素 。 如果 | 
数组 一 旦 改变 ， 那 么 此 函数 的 运用 也 就 没有 意义 了 。 如 果 没 有 提供 callbackO 函 数 ， 那 么 | 
array_filter() 将 删除 input 中 所 有 值 为 false 的 元 素 。 | 

通过 POST 方法 实现 多 图 片上 传 ， 在 创建 form 表单 时 ， 必 须 指定 enctype="multipart/ | 
form-data" 属 性 。 如 果 要 通过 隐藏 域 MAX FILE SIZE 的 值 对 上 传 文件 的 大 小 进行 限制 ， | 
那么 必须 将 隐藏 域 放置 在 上 传 文件 的 文件 域 之 前 ， 和 否则 是 不 会 起 到 作用 的 。 


多 学 两 招 : | 
通过 伪 静 态 技术 隐藏 PHP 文件 后 缓 , 是 通过 修改 Apache 服务 器 的 配置 文件 httpd.conf | 
来 完成 的 。 首先 , 将 和 红 0adModule rewrite module modules/mod rewrite.so 前 面 的 “#” 去 掉 ， | 
并 启动 该 项 。 然 后 ， 查 找 httpd.conf 文件 ， 找 到 其 中 的 “AllowOverride” 项 ， 将 它 的 值 都 
改 为 All， 保 存 并 重新 启动 Apache 服务 器 ， 即 可 使 修改 生效 。 最 后 ， 在 实例 根 目 录 下 创 | 
建 htaccess 文件， 实现 对 PHP 文件 后 缓 的 隐藏 操作 。 | 


实例 076 通过 header0O) 函 教 进行 下 载 

( 实例 位 置 : 配套 资源 \SL\04\076 视频 位 置 : 配套 资源 \SP\04\076 ) 
实例 说 明 | 
除了 可 以 通过 链接 方式 下 载 文 件 之 外 ， 还 可 以 通过 header0) 函 数 完成 下 载 的 操作 。 例 | 
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如 ， 本 实例 就 是 应 用 header0 函 数 实现 文件 的 下 载 ， 如 果 下 载 的 文件 不 存在 ， 则 给 出 提示 


信息 。 运 行 结果 如 图 4.37 所 示 。 


实现 过 程 


4| 
外 起 打 开 职 保存 此 文件 虽 ? 
[1 名 称 : 12759792140.png 


欧 型 ，PNG 图 像 , 1.95 KB 
发 送 者 : 127.0.0.1 


打开 保 序 回 
日 We 


图 4.37 header0 函 数 文件 下 载 


具体 步骤 如 下 : 
(1) 在 实例 074 的 基础 上 ， 添 加 单 击 图 片 下 载 的 功能 。 其 实现 过 程 是 为 输出 的 图 片 
创建 超 链接 ， 链 接 到 download.php 文件 ， 再 利用 header() 函 数 通过 download.php 完成 文件 
下 载 的 操作 。 在 index.php 文件 中 所 做 的 修改 如 下 : 
<td width="245" height="100" align="center” valign="middle" bgcolor="#FOFOF0"><a href= 
"download-<?php echo $myrow[file_test]:?>.html" title=" 点 击 即 可 下 载 ! "><?php echo "<img src=\"$myrow 
[file_test]\" width=\"250\ height=\"100\" border=\"0\>"?></a></td> 


(2) 创建 download.php 文件 ， 应 用 header0 函 数 实现 文件 的 下 载 。 其 代码 如 下 : 


<2php 
header("Content-type: text/html: charset=UTF-8"); /设置 文件 编码 格式 
$path=$_GET[path']; /获取 文件 路 径 
if(!lempty($path) and lis_null($path)){ /判断 变量 是 否 为 空 ,是否 为 NULL 
S$filename=basename($path):; // 获 取 文 件 名 
$file=@fopen($path,"r"); 
这 $file){ 
header("Content-type:application/octet-stream"); 。” // 输 出 MIME 类 型 
header("Accept-ranges:bytes"): // 接 受 的 范围 单位 
header("Accept-length:".filesize($path)): // 文 件 长 度 
header("Content-Disposition:attachment:filename=".$filename); // 缺 省 时 文件 保存 对 话 
框 中 的 文件 名 称 
echo fread($file,filesize($path)): 1/ 读 取 文件 
fclose($file); // 关 闭 文件 
exit; // 退 出 
}else{ 
echo "<script>alert(' 您 下 载 的 文件 不 存在 ! ); history.backQ:</script>"; 
b 
?> 
技术 要 点 


通过 HTTP 方式 下 载 文件 ， 主 要 应 用 headerO 函 数 。 
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header0 函 数 属于 HTTP 函数 。 其 作用 是 以 HTTP 协议 将 HTML 文档 的 标 头 送 到 浏览 ， 
并 告诉 浏览 器 具体 怎么 处 理 这 个 页 面 。headerO 函 数 的 语法 如 下 : | 
void header ( string string [, bool replace [, int http_response_code]] ) 
参数 说 明 : 
回 string: 发 送 的 标 头 。 
replace: 如 果 一 次 发 送 多 个 标 头 ,对 于 相似 的 标 头 是 蔡 换 还 是 添加 。 如 果 是 false， | 
则 强制 发 送 多 个 同类 型 的 标 头 。 默 认 是 tue， 即 替换 。 | 
加 ”http_response_code: 强制 HTTP 响应 为 指定 值 。 
通过 HTTP 下 载 的 代码 如 下 : 
header("Content-type: application/x-gzip"); 
header("Content-Disposition: attachment': filename= 文 件 名 "); 
header("Content-Description: PHP3 Generated Data"):; > 
HTTP 标 头 有 很 多 ， 这 里 介绍 的 是 下 载 的 HTTP 标 头 。 其 代码 如 下 : 
header(Content-Disposition: attachment filename="filename"™); 
在 应 用 的 过 程 中 , 唯一 需要 改动 的 就 是 filename， 即 将 filename 替换 为 要 下 载 的 文件 。 


多 学 两 招 : 


通过 header() 函 数 ， 不 但 可 以 实现 文件 的 下 载 ， 还 可 以 实现 下 面 3 个 功能 : 
(1) 重 定 向 ， 这 是 最 常用 的 功能 。 
header("Location: http://www.mrbccd.com"); 
(2 ) 强制 客户 端 每 次 访问 页 面 时 获取 最 新 资料 ， 而 不 是 使 用 存储 于 客户 端的 缓存 。 
/设置 页 面 的 过 期 时 间 ( 用 格林 威 治 时间 表 示 )。 
header("Expires: Mon, 08 Jul 2008 08:08:08 GMT"); 
// 设 置 页 面 的 最 后 更 新 日 期 (用 格林 威 治 时 间 表 示 )， 使 浏览 器 获取 最 新 资料 
header("Last-Modified: " . gmdate("D, d MY H:i:s") . "GMT"); 


header("Cache-Control: no-cache, & must-revalidate"); // 控 制 页 面 不 使 用 缓存 | 

header("Pragma: no-cache"); /参数 ( 与 以 前 的 服务 器 兼容 ) , 即 兼容 | 
HTTP1.0 协议 | 

header("Content-type: & application/file"): // 输 出 MIME 类 型 

header("Content-Length: & 227685"); // 文 件 长 度 

header("Accept-Ranges: bytes"); // 接 受 的 范围 单位 

// 默 认为 文件 保存 对 话 框 中 的 文件 名 称 


header("Content - Disposition: attachment: filename=$filename"); /实现 下 载 
(3) 输出 状态 值 到 浏览 器 ， 控 制 访问 权限 。 
header(HTTP/1.1 401 Unauthorized): 
header('status: 401 Unauthorized"); 
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实例 077 重新 定义 上 传 文件 的 名 称 


( 实例 位 置 : 配套 资源 \SL\04\077 ) 


实例 说 明 
应 用 POST 方法 上 传 文件 时 ， 需 要 将 上 传 文件 保存 到 服务 器 指定 的 目录 中 ， 这 时 可 能 


| 会 出 现 因 名 称 相同 而 文件 相互 替换 的 情况 。 为 了 解决 上 述 问题 ， 可 以 应 用 basename() 函 数 


| 和 随机 函数 mt_randO 对 上 传 文件 进行 重新 命名 。 在 运行 本 实例 时 ， 如 果 用 户 成 功 上 传 重 定 


义 名 称 后 的 文件 ， 将 弹出 新 的 文件 名 称 对 话 框 ， 如 图 4.38 所 示 。 


| 实现 过 程 


AAS 文件 名 被 苦 换 为 724020100710062127 既 验 技巧 .rar 
图 4.38 重新 定义 上 传 文件 的 名 称 


在 本 实例 中 ， 关 键 是 在 定义 上 传 文件 的 名 称 时 应 用 随机 函数 mt rand0、 时 间 戳 以 及 


basename() 函 数 。 其 关键 代码 如 下 : 


$date=date("YmdHis"); // 定 义 随机 数 
$filename=mt_rand(1000,9999).$date.basename($_FILES['"up_picture']['name']);// 定 义 上 传 文件 名 称 
echo "<script>alert(' 文 件 名 被 替换 为 ".$filename.");</script>"; 


| $path=' /upfile/.$filename: /定义 上 传 文件 名 称 和 存储 位 置 
| 技术 要 点 


应 用 本 实例 也 可 以 实现 多 文件 上 传 的 功能 , 但 并 非 本 实例 中 的 技术 重点 , 故 不 青 袭 述 。 
这 里 将 介绍 一 种 给 上 传 文件 命名 的 方法 。 

basename() 函 数 用 于 返回 指定 文件 目录 中 的 基本 文件 名 ， 语 法 如 下 : 

string basename(string path [, string suffix]) 

参数 说 明 : 

path: 指定 文件 的 路 径 。 

回 suffix: 可 选 参数 ， 如 果 文件 路 径 以 suffix 结尾 ， 那 么 这 部 分 内 容 被 去 掉 。 

通过 这 个 函数 获取 到 上 传 文件 的 原始 名 称 ， 并 对 这 个 名 称 进行 重新 定义 ， 进 而 避免 在 
将 文件 上 传 到 服务 器 后 出 现 重 名 的 问题 。 


多 学 两 招 : 

在 通过 表单 中 的 文件 域 提交 上 传 文件 时 ， 如 果 在 form 中 定义 了 “enctype="multipart/ 
form-data"” 属 性 ， 那 么 在 获取 上 传 文件 的 原始 名 称 时 必须 使 用 $_FILES 全 局 变量 ,此 时 如 
果 使 用 $ POST 是 获取 不 到 值 的 。 
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本 章 读者 可 以 学 到 如 下 实例 : 


豆 吾 于 于 于 于 对 于 于 芋 


各 各 有 


吾 于 于 于 于 于 于 
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实例 092 
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实例 096 
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将 
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准 


启动 MySQL 服务 

连接 MySQL 服务 

关闭 MySQL 服务 

创建 PHP 图 书 数 据 库 

选择 PHP 图 书 数据 库 

删除 PHP 图 书 数据 库 

在 PHP 图 书 数 据 库 中 创建 图 书信 息 表 
查看 图 书信 息 表 

修改 图 书信 息 表 

重 命名 图 书信 息 表 

删除 图 书信 息 表 

向 图 书信 息 表 中 添加 数据 

修改 图 书信 息 表 中 的 数据 

删除 图 书信 息 表 中 所 有 数据 

删除 图 书信 息 表 中 指定 数据 

通过 phpMyAdmin 修改 MySQL 用 户 密码 
通过 phpMyAdmin 设置 数据 库 、 数 据 表 编码 
phpMyAdmin 操作 数据 库 

phpMyAdmin 操作 数据 表 

phpMyAdmin 操作 数据 


需 
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实例 078 ”启动 MySQL 服务 


( 实 便 位置 : 配套 资源 \SL\05\078 视频 位 置 : 配套 资源 \SP\05\078 ) 


实例 说 明 


| 如 果 想 学 习 PHP 语言 ， 那 么 就 必须 学 习 MySQL。PHP 与 MySQL 是 最 佳 的 组 合 ， 虽 
| 然 PHP 如 今 可 支持 很 多 的 数据 库 ， 如 Access、SQL Server、Oracle、DB2 等 ， 但 是 无 论 在 
| LAMP 组 合 (LINUX + Apache + MySQL + PHP) 还 是 AMP 组 合 (Apache + MySQL + PHP) 
| 中 ，MySQL 的 地 位 丝毫 没有 动摇 。 

| 在 Windows 操作 系统 中 ， 启 动 MySQL 服务 可 以 使 用 命令 模式 进行 。 


| 实现 过 程 
| 在 Windows 操作 系统 下 启动 MySQL 服务 的 步骤 如 下 : 

| (1) 选择 “开始 ”/“ 和 运行” 命令， 在 弹出 的 运行 窗口 中 输入 “cmd” 命 令 ， 按 Enter 
| 键 进入 命令 提示 符 窗口 ， 如 图 5.1 所 示 。 

| (2) 在 命令 提示 符 下 输入 启动 MySQL 服务 的 命令 ， 如 图 5.2 所 示 。 

到 | 
Be 
扣 | 画 可 


NET HELPMSG 21 


Cus] we | wsw. | 
| ”图 5.1 启动 MySQL 服务 的 第 一 步 图 5.2 成 功 启动 MySQL 服务 
| 技术 要 点 
| 本 实例 的 关键 是 在 命令 提示 符 下 输入 启动 MySQL 服务 的 命令 ， 完 成 MySQL 服务 的 
| 启动。 其 命令 如 下 : 
| net start mysql 


实例 079 连接 MySQL 服务 器 


( 实例 位 置 : 配套 资源 \SL\05\079 视频 位 置 : 配套 资源 \SP\05\079 ) 


”实例 说 明 
| 启动 MySQL 服务 只 是 应 用 MySQL 的 第 一 步 , 如 果 想 要 操作 MySQL 数据 库 , 就 要 学 
会 连接 MySQL 服务 器 。 本 实例 将 详细 讲解 在 命令 提示 符 下 如 何 连接 MySQL 服务 器 。 

| 实现 过 程 


连接 MySQL 服务 器 的 步骤 如 下 : 
(1) 进入 命令 提示 符 窗口 。 
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(2) 如 果 MySQL 默认 安装 在 C:\ 盘 根 目录 下 ， 在 未 设置 环境 变量 的 情况 下 ， 需 要 在 | 
命令 提示 符 下 进入 “mysql”\“bin” 文 件 夹 ， 输 入 命令 。 假 设 用 户 名 为 root， 密 码 为 111， | 
输入 的 命令 如 下 : | 

mysql -uroot -pl11 


按 Enter 键 ， 输 出 如 图 5.3 所 示 的 内 容 ， 表 示 连 接 MySQL 服务 器 成 功 。 


图 5.3 连接 MySQL 服务 器 成 功 


(3) 如 果 在 本 地 用 户 机 上 运行 程序 ， 可 以 直接 输入 命令 “mysql -uroot -p111” 来 连 | 
接 MySQL 服务 器 ， 但 是 为 了 安全 起 见 ， 避 免 他 人 得 到 连接 MySQL 服务 器 的 密码 进行 非 | 
法 操作 ， 最 好 使 用 如 下 命令 : 


mysql -uroot -p 


根据 提示 输入 密码 ， 完 成 连接 ， 如 图 5.4 所 示 。 


图 5.4 连接 MySQL 服务 器 成 功 


技术 要 点 


选择 “开始 ”/“ 运 行 ”命令 ， 在 弹出 的 窗口 中 输入 “cmd” 命 令 入 命令 提示 符 提 
示 框 。 输 入 如 下 命令 


mysql -uName ~p Password 


“mysql” 与 “-u” 和 “Name” 和 “-p” 之 间 有 一 个 空格 。Name 表示 进入 MySQL 服 
务 器 的 用 户 名 。Password 表示 进入 MySQL 服务 器 的 密码 。 | 


实例 080 关闭 MySQL 服务 


( 实例 位 置 : 配套 资源 \SL\05\080 视频 位 置 : 配套 资源 \SP\05\080 ) 


实例 说 明 | 

为 了 有 效 节省 系统 资源 ， 在 进行 MySQL 数据 库 操作 后 ， 需 要 及 时 将 MySQL 服务 关 | | 
闭 。 关 闭 MySQL 服务 与 启动 MySQL 服务 相 类 似 ， 可 以 通过 两 种 方法 实现 关闭 MySQL 
服务 。 通 过 本 实例 ， 相 信用 户 会 将 关闭 MySQL 服务 的 两 种 方法 熟 记 于 心中 。 
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具体 步 又 如 下 : 


| (1) 在 命令 提示 符 下 ， 输 入 命令 连接 MySQL， 通 过 MySQL 数据 库 函 数 “user” 显 
| 示 数 据 表 中 的 内 容 ， 如 图 5.5 所 示 。 


图 5.5 查询 表 信息 


(2) 通过 命令 “exit” 断 开 与 MySQL 的 连接 ， 如 图 5.6 所 示 。 
(3) 输入 命令 “net stop mysql”， 按 Enter 键 ， 关 闭 MySQL 服务 ， 如 图 5.7 所 示 。 


°C:\WINDOYS\systen32\cad. exe 5 C:AMWINDOWS\s7stel 


| 图 5.6 ” 断 开 与 MySQL 连接 图 5.7 关闭 MySQL 服务 
| 技术 要 点 
命令 提示 符 下 ， 输 入 命令 : 

(1) 断 开 MySQL 数据库 连 接 。 


exit 
(2) 关闭 MySQL 服务 。 


net stop mysql 


实例 081 创建 PHP 图 书 数 据 库 


”实例 说 明 

| 如 果 用 户 已 经 掌握 如 何 启动 MySQL 服务 、 连 接 MySQL、 断 开 MySQL 和 关闭 MySQL 
| 服务 。 下 面 就 走 进 MySQL 数据 库 ， 学 习 如 何 创建 数据 库 。 创 建 数据 库 的 主要 目的 是 将 同 
| 类 的 或 者 是 同一 个 项 目 中 的 数据 表 ， 进 行 分 类 存储 ， 方 便 开发 人 员 查 找 和 使 用 。 本 实例 通 
| 过 数据 库 函 数 “CREATE DATABASE” 创 建 PHP 图 书 数据 库 。 
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具体 步骤 如 下 : 
(1) 进入 命令 提示 符 窗口 ， 启 动 MySQL 服务 ， 连 接 MySQL 服务 器 。 
(2) 通过 数据 库 函 数 在 命令 提示 符 下 编写 命令 。 代 码 如 下 : 


CREATE DATABASE DB MRBOOK: 


按 Enter 键 ， 行 结果 如 图 5.8 所 示 。 


图 5.9 所 示 。 


in ysql create database db_mrbook; 
Query OK, 1 row affected (0.68 sec) 


图 5.8 创建 数据 库 db_mrbook 图 5.9 数据 库 db_mrbook 存在 于 数据 库 列表 中 | 


(4) 断 开 数 据 库 连接 ， 关 闭 MySQL 服务 。 


(1) 创建 数据 库 函 数 。 
CREATE {DATABASE |SCHEMA} [IF NOT EXISTS] db_name: 


CREATE DATABASE 用 于 创建 数据 库 ， 并 进行 命名 。 参 数 db_name 表示 需要 创建 的 
数据 库 名 称 。 
(2) 获取 数据 库 列表 。 
SHOW {DATABASES | SCHEMAS} [LIKE 'pattern']: 


SHOW DATABASES 可 以 列举 数据 库 名称 。 
实例 082 选择 PHP 图 书 数 据 库 


实例 说 明 


创建 数据 库 的 目的 是 向 数据 库 中 存储 同类 型 或 者 同一 个 项 目下 的 所 有 数据 表 。 用 户 创 
建 数据 库 后 ， 还 需要 通过 命令 选择 指定 的 数据 库 ， 否 则 计算 机 无 法 自动 识别 创建 的 数据 表 | 


属于 哪个 数据 库 ， 还 会 出 现 错误 提示 ， 如 图 5.10 所 示 。 


* 125s 
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本 实例 通过 数据 库 函 数 “USE db name” 实 现 选择 PHP 图 书 数据 库 。 
| 实现 过 程 


具体 步骤 如 下 : 

| (1) 在 命令 提示 符 窗口 下 ， 通 过 命令 启动 MySQL 服务 ， 并 连接 MySQL。 创 建 数据 
库 并 将 此 数据 库 命 名 为 db_mrbook。 

| (2) 通过 “show databases;” 语 句 ， 查 看 在 MySQL 服务 器 主机 上 列举 的 数据 库 名 称 

| 是 否 包含 用 户 指 定 的 数据 库 。 

| (3) 输入 命令 “use db_mrbook:;”， 将 数据 库 use db_mrbook 作为 当前 默认 数据 库 。 按 

| Enter 键 ， 命 令 窗口 将 输出 如 图 5.11 所 示 的 内 容 。 


\cad. exe [- 口 [zx| 
国 


图 5.10 错误 提示 图 5.11 选择 图 书 数据 库 
| (4) 关闭 数据 库 连接 ， 关 闭 MySQL 服务 。 
| 技术 要 点 
USE db_name 语句 可 以 通过 MySQL 把 db_name ang 认 ( 当 前 ) 数据 库 ， 并 
| 应 用 于 后 续 语 句 。 该 数据 库 保持 为 默认 数据 库 ， 直 到 语 段 的 结尾 ， 或 者 直到 发 布 一 个 不 同 
| 的 USE 语句 。 语 法 格式 如 下 : 
| USE db_name; 

参数 db_name 表示 需要 使 用 的 数据 库 名 称 ， 该 名 称 必须 是 合法 的 。 


实例 083 ”删除 PHP 图 书 数 据 库 


| 实例 说 明 

如 果 某 个 数据 库 失 去 了 存在 的 价值 ， 那 么 为 了 节省 系统 硬盘 资源 ， 提 高 MySQL 的 运 
| 行 效率 ， 建 议 从 硬盘 上 删除 此 数据 库 。 删 除数 据 库 可 以 通过 打开 MySQL 安装 目录 ， 进 入 
| data 文件 夹 ， 删 除 指定 的 数据 库 文 件 夹 来 完成 ， 还 可 以 通过 在 命令 提示 符 下 输入 删除 命令 
| 删除 数据 库 。 本 实例 讲解 在 命令 提示 符 下 输入 命令 ， 实 现 删除 PHP 图 书 数据 库 。 

| 实现 过 程 


具体 步骤 
C1 py 仿 提 示 符 窗口 ， 启 动 MySQL 服务 ， 连 接 MySQL 服务 器 。 
(2) 通过 命令 语句 “show databases;”， 查 看 在 MySQL 服务 器 主机 上 列举 的 数据 库 名 
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称 是 否 存在 数据 库 “db mrbook”。 | 
(3) 使 用 命令 语句 “use db_mrbook;”， 为 数据 库 “db_mrbook” 做 标记 ， 使 数据 库 | 
“db_mrbook” 为 当前 默认 数据 库 ， 如 图 5.12 所 示 。 | 
vm 


图 5.12 选择 图 书 数据 库 


(4) 在 命令 行 输入 “drop database db_name;” 语 句 ， 删 除数 据 库 的 同时 也 删除 数据 库 | 
中 的 所 有 表 。 所 以 笔者 建议 在 命令 行 输 入 命令 删除 数据 库 时 ， 最 好 清查 数据 库 中 的 所 有 表 | 
名 ,以 防止 意外 删除 运行 程序 中 的 作用 表 , 而 造成 不 必要 的 损失 。 查 看 数据 库 中 所 有 表 名 ， 
可 以 通过 命令 语句 “show tables;” 实 现 。“show tables;” 语 句 获 取 指 定数 据 库 中 所 有 的 表 ， | 
如 图 5.13 所 示 。 
(5) 使 用 命令 行 语句 删除 PHP 图 书 数据 库 “db_mrbook”， 如 图 5.14 所 示 。 


二 C:AWINDOWS\systea32\cad- exe EE 


5 C:\FINDOYS\systen32\cad. exe - a7sdl EE 


nysql> drop database db_mrbook; 
Juery OK. 1 row affected (8.8B sec) 


Inysal 


1 row in set (80.00 sec> 


图 5.13 显示 图 书 数据 库 中 的 数据 表 图 5.14 删除 图 书 数据 库 


(6) 断 开 与 MySQL 服务 器 的 连接 ， 关 闭 MySQL 服务 。 
技术 要 点 


DROP DATABASE 语句 用 于 删除 数据 库 中 的 所 用 表格 和 数据 库 。 使 用 此 语句 时 要 非常 | 
小 心 ， 如 果 要 使 用 DROP DATABASE， 就 必须 获得 数据 库 DROP 权限 。 其 语法 格式 如 下 : 
DROP {DATABASE | SCHEMA} [IF EXISTS] db_name': 


实例 084 在 PHP 图书 数据 库 中 创建 图 书信 息 表 


实例 说 明 
数据 库 的 主要 作用 是 保存 数据 表 ， 而 数据 表 的 作用 是 保存 数据 信息 。 本 实例 通过 
“CREATE TABLE” 语 句 实现 在 PHP 图 书 数据 库 中 创建 图 书信 息 表 ， 如 图 5.15 所 示 。 


图 5.15 创建 图 书信 息 表 
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| 实现 过 程 
| (CD 启动 MySQL 服务 ， 建 立 MySQL 服务 器 连接 。 
全 办 | (2) 在 命令 提示 符 窗口 下 通过 命令 语句 “create database db_name;” 创 建 名 称 为 “db_ 


| mrbook” 的 数据 库 。 
(3) 使 用 “use db_name;” 语 句 设 定数 据 库 标记 。 
| (4) 通过 “create table tb_name();” 语 句 创建 数据 表 ， 代 码 如 下 : 
mysql> use db_mrbook:; 
Database changed 
mysql> create table tb_mrbook( 
-> id int(4) auto_increment prima 
-> name varchar(20) NOT NULL, 
-> pwd varchar(20) NOT NULLD):; 
Query OK, 0 rows affected (0.05 sec) 


| (5) 断 开 MySQL 服务 器 连接 ， 结 束 MySQL 服务 。 
| 技术 要 点 
| “创建 数据 表 使 用 “CREATE TABLE” 语 句 ， 其 语法 格式 如 下 : 
CREATE TABLE table name 
(create_definition,....) 
[table_opotions] 
[select_statement] 
参数 说 明 : 
回 table name: 要 创建 的 数据 表 名 。 
回 “create _definition: 这 是 表 的 列 属性 部 分 。MySQL 要 求 在 创建 表 的 时 候 ， 表 要 至 
少 包含 一 列 。 
加 ”table_options: 表 的 一 些 特性 参数 。 
加 select_ statement: SELECT 语句 描述 部 分 ， 用 它 可 以 快速 地 创建 表 。 
下 面 介 绍 列 属性 部 分 ， 每 一 列 定义 的 具体 格式 如 下 : 
col_name type[NOT NULL | NULL][DEFAULT default value][AUTO INCREMENTI[PRIMARY KEY] 
参数 说 明 : 
回 ”col name: 表示 字段 名 。 
回 type: 表示 字段 类 型 。 
回 NOT NULL 或 者 NULL: 指出 该 列 是 否 允 许 是 空 值 。 所 谓 的 空 值 是 “不 知道 
或 “无 意义 ”的 值 ， 但 是 数据 “0” 和 空格 都 不 是 空 值 ， 系 统一 般 默 认 人 允许 为 空 
值 ， 所 以 当 不 允许 为 空 值 时 ， 必 须 使 用 NOT NULL 。 
DEFAULT default_value: 表示 默认 值 。 
AUTO INCREMENT: 表示 是 否 为 自动 编号 ， 每 个 表 只 能 有 一 个 AUTO 
INCREMENT 列 ， 并 且 必 须 被 索引 。 
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回 “PRIMARY KEY: 表示 是 否 为 主键 。 它 是 一 个 唯一 的 KEY， 还 有 一 个 额外 的 约 | 
束 ， 即 所 有 键 列 必 须 被 定义 为 NOT NULL。 在 MySQL 中 ， 该 列 被 命名 为 | 
PRIMARY。 一 个 表 只 能 有 一 个 PRIMARY KEY。 如 表 中 没有 一 个 PRIMARY | 
KEY, 而 某 些 应 用 程序 要 PRIMARY KEY, MySQL 将 返回 第 一 个 没有 任何 NULL | 
he ping 作为 PRIMARY KEY。 一 个 PRIMARY KEY 可 以 是 一 个 多 列 | 


索引 ， 不 能 在 一 个 列 规格 说 明 中 使 用 PRIMARY KEY 键 属性 来 创建 一 个 多 
列 索 这 样 做 将 仅仅 标记 单个 列 作为 主键 ， 必 须 使 用 PRIMARY KEY(index 


col name, ..) 名 法。 如果 PRIMARY KEY 或 UNIQUE 键 只 由 一 个 列 组 成 ， 并 且 


列 类 型 是 整 型 ， 则 可 以 用 _rowid 引用 它 。 


以 上 是 创建 一 个 数据 表 的 一 些 基础 知识 ， 它 看 起 来 十 分 复杂 ， 但 在 实际 的 应 用 中 使 用 


最 基本 的 格式 创建 数据 表 即 可 ， 具 体格 式 如 下 。 
create table table_ name( 列 名 1 属性 ， 列 名 2 属性 .…) 


实例 085 查看 图 书信 息 表 


实例 说 明 


查看 信息 表 分 两 种 形式 : 第 一 种 是 查看 信息 表 结 构 ， 第 二 种 是 查看 信息 表 数 据 。 查 看 
信息 表 数 据 信息 ， 需 要 使 用 “select” 查 询 语句 。 本 实例 通过 show columns 命令 查看 信息 | 


表 结构 ， 运 行 结果 如 图 5.16 所 示 。 


图 5.16 查看 信息 表 结 构图 


实现 过 程 
具体 步 又 如 下 : 


(1) 启动 MySQL 服务 ， 在 命令 提示 符 窗口 输入 命令 ， 建 立 MySQL 连接 。 通 过 “create | 


database db name:” 和 “create table tb_name;” 语 句 创建 数据 库 和 数据 表 。 
(2) 通过 命令 语句 “show columns from tb_name;” 查 看 表 结 构 ， 其 代码 如 下 : 
mysql> show columns from tb_mrbook; 


(3) 通过 “exit” 和 “net stop mysql; ”语句 断 开 数 据 库 服务 器 并 关闭 MySQL 服务 。 
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技术 要 点 
| 查看 数据 表 结 构 使 用 show columns 命令 ， 其 语法 如 下 : 
加 给 | show [full] columns ”tom 数据 表 名 [fom 数据 库 名 ]; 


或 写成 
| show [ful] columns from 数据 表 名 .数据 库 名 : 


实例 086 修改 图 书信 息 表 


| 实例 说 明 

| 旦 序 员 在 建立 数据 表 时 ， 难 免 在 表 的 结构 上 出 现 错误 ， 例 如 ， 将 “Date” 类 型 数据 设 
| 置 为 “int” 类 型 , 这 时 就 需要 更 改 表 的 结构 。 本 实例 通过 增加 表 “tb_mrbook” 中 的 “last_date” 
| 字段 ， 并 设置 数据 类 型 为 “Date” 实 现 修改 信息 表 ， 运 行 结果 如 图 5.17 所 示 。 


二 C:\WINDOYS\systen32\cad. exe - aysql -uroot -p 固 日 加 


alter table th_mrbook a 
Kk, 0 rows affected (0.0 
:8 Duplicates: 0 Warnings: 


图 5.17 修改 图 书信 息 表 


”实现 过 程 
| 具体 步骤 如 下 ; 
| (1) 启 动 MySQL 服务 ,在 命令 提示 符 窗口 下 ,建立 MySQL 连接 。 通 过 “create database 
| db_name;” 和 “create table tb_name;” 语 句 创 建 数 据 库 和 数据 表 。 
(2) 使 用 命令 语句 “show columns from tb_name;” 查 看 表 结 构 。 
(3) 在 命令 提示 符 下 输入 如 下 命令 : 
mysql> alter table tb_mrbook add last_date Date; 
| 按 Enter 键 ， 运 行 结果 如 图 5.17 所 示 。 
| (4) 通过 “exit” 和 “net stop mysql; ”语句 断 开 数 据 库 服 务 器 并 关闭 MySQL 服务 。 
| 技术 要 点 
修改 表 结 构 采 用 “alter table” 命 令 。 修 改 表 结 构 是 指 增加 或 者 删除 字段 、 修 改 字段 
| 名 称 或 者 字段 类 型 、 设 置 取消 主键 外 键 、 设 置 取消 索引 以 及 修改 表 的 注释 等 。 其 语法 
| 如 下 : 
alter [IGNORE] table 数据 表 名 alter_spec[,alter_spec]…; 
| 注意 , 当 指 定 IGNORE 时 , 如 果 出 现 重 复 的 行 , 则 只 执行 一 行 , 其 他 重复 的 行 被 删除 。 
| 其 中 ，alter spec 子 句 定义 要 修改 的 内 容 ， 其 语法 如 下 : 
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alter_specification: | 


ADD [COLUMN] create_definition [FIRST | AFTER column name ] -- 添 加 新 字段 | 
ADD INDEX [index_name] (index_col name,...) -- 添 加 索引 名 称 | 
ADD PRIMARY KEY (index col name,...) -- 添 加 主键 名 称 | 
ADD UNIQUE [index_ name] (index_col name,...) -- 添 加 唯一 索引 

ALTER [COLUMN] col name {SET DEFAULT literal | DROPDEFAULT} -修改 字段 名 称 
CHANGE [COLUMN] old_col_ name create definition 一 修改 字段 类 型 

MODIFY [COLUMN] create_definition 一 修改 子 句 定义 字段 

DROP [COLUMN] col name 一 加 除 字 段 名 称 

DROP PRIMARY KEY 一 加 除 主键 名 称 | 
DROP INDEX index name 一 删除 索引 名 称 | 
RENAME [AS] new tbl name -- 更 改 表 名 | 
table_options 


实例 087 重 命名 图 书信 息 表 


实例 说 明 | 
MySQL 数据 表 是 不 允许 重 名 的 ， 所 以 在 同一 个 数据 库 中 绝对 不 会 出 现 两 个 名 称 相 同 
的 表 ， 但 是 一 般 情况 下 ， 程 序 员 希 望 自己 创建 的 数据 表 能 更 贴近 自己 的 项 目 ， 所 以 对 数据 | 
表 重 命名 有 时 是 不 可 避免 的 。 本 实例 通过 “rename table” 命 令 实现 对 图 书信 息 表 重 命名 ， 
运行 结果 如 图 5.18 所 示 。 


rp [|x| 


图 5.18 重 命名 图 书信 息 表 
实现 过 各 

具体 步骤 如 下 ; | 
(1) 在 命令 提示 符 窗口 下 ， 启 动 MySQL 服务 ， 建 立 MySQL 连接 ， 创 建 数据 库 并 建 | 
立 数据 表 。 | 
(2) 使 用 命令 语句 “show tables;” 显 示 当 前 数据 库 中 的 所 有 表 。 | 

(3) 在 命令 提示 符 下 输入 如 下 命令 : 

mysql> alter table tb_mrbook rename tb_mrbook php; 

按 Enter 键 ， 完 成 数据 表 的 重 命名 操作 ， 运 行 结果 如 图 5.18 所 示 。 
(4) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 | 
技术 要 点 
命名 数据 表 采 用 rename table 命令 ， 语 法 格式 如 下 : | 
rename table 数据 表 名 1 To 数据 表 名 2: | 


可 


二 
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alter table 数据 表 名 1 rename 数据 表 名 2: 


SA 实例 088 ”删除 图 书信 息 表 
oh 


“drop database db _name” 语 句 删除 数据 库 的 同时 会 连带 删除 数据 库 中 的 所 有 数据 表 ， 
| 如 果 只 想 删除 数据 库 中 的 某 个 表 ， 而 保留 其 他 所 有 表 ， 显 然 “drop database db_ name” 语 
| 名 已 经 不 再 适用 ， 这 时 可 以 使 用 “drop table tb_name;” 语 句 ， 运 行 结果 如 图 5.19 所 示 。 


图 5.19 删除 图 书信 息 表 


| 实现 过 程 
| 具体 步骤 如 下 ; 

(1) 在 命令 提示 符 窗口 下 , 启动 MySQL 服务 , 通过 输入 命令 连接 到 MySQL 服务 器 。 

(2) 使 用 命令 语句 “show tables;” 显 示 当 前 数据 库 中 的 所 有 表 。 

(3) 在 命令 提示 符 下 输入 如 下 命令 ， 删 除 指定 数据 表 。 

drop table tb_mrbook; 
按 Enter 键 ， 运 行 结果 如 图 5.19 所 示 。 

| (4) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 
| 技术 要 点 
| 删除 数据 表 的 操作 很 简单 ， 同 删除 数据 库 的 操作 类 似 ， 使 用 drop table 命令 就 可 以 实 
| 现 。 其 语法 格式 如 下 : 
| drop table 数据 表 名 ; 


实例 089 向 图 书信 息 表 中 添加 数据 


| 实例 说 明 


| 建立 数据 库 是 为 了 把 不 同类 型 或 者 不 同 要 求 的 数据 分 类 存储 在 不 同 的 数据 表 中 ,创建 
| 数据 表 是 为 了 将 相同 类 型 或 者 相同 要 求 的 数据 存储 在 同一 表 中 。 本 实例 讲解 通过 SQL 语 
| 名 向 图 书信 息 表 中 添加 数据 ， 运 行 结果 如 图 5.20 所 示 。 
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图 5.20 向 图 书信 息 表 中 添加 数据 
实现 过 程 
具体 步骤 如 下 : 
(1) 在 命令 提示 符 窗口 下 , 启动 MySQL 服务 , 通过 命令 行 语句 连接 MySQL 服务 器 ， 
创建 数据 库 并 建立 数据 表 。 
(2) 编辑 Insert 语句 ， 执 行 数据 的 添加 操作 ， 其 代码 如 下 : 
insert into tb_mrbook php(id,name,pwd,last_date)values (",'lizhonghua','5315',nowO); 


(3) 当 提 示 符 窗口 出 现 如 图 5.21 所 示 内 容 时 ， 表 示 数 据 添 加 成 功 。 


图 5.21 数据 添加 成 功 


(4) 通过 SELECT 语句 查询 数据 表 中 的 内 容 ， 显 示 结 果 如 图 5.20 所 示 。 

(5) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 
技术 要 点 

建立 一 个 空 的 数据 表 时 ， 首 先 要 想到 的 就 是 如 何 向 数据 表 中 添加 数据 。 这 项 操作 可 以 
通过 INSERT 命令 来 实现 。Insert 语句 的 语法 如 下 : 


insert into 数据 表 名 (column name,column name?2, ... ) values (valuel, value2, ... ); 


实例 090 ”修改 图 书信 息 表 中 的 数据 
实例 说 明 
用 户 向 数据 表 中 插入 数据 信息 时 ， 在 手动 输入 的 过 程 中 很 有 可 能 将 信息 输入 错误 。 这 
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| 个 时 候 就 需 要 SQL 语句 对 错误 的 数据 进行 修改 。 本 实例 通过 修改 语句 ， 将 图 书信 息 表 中 
| 操作 数据 表 的 时 间 进 行 修改 ， 运 行 结 果 如 图 5.22 所 示 。 


5 C:\WINDOYS\systen32\cad. exe 一 nysql -uroot -p 


"2818-87-11’ where id=3; 


| sql> bp_mr ate='2818-97-11， where id=2; 


| > | b_mrhook_ph date=’2018-87-11’ where i 


| 图 5.22 修改 图 书信 息 表 中 的 数据 


具体 步骤 如 下 : 
| (1) 在 命令 提示 符 窗口 下 ， 启 动 MySQL 服务 ， 通 过 命令 行 语句 连接 MySQL 服务 器 ， 
| 创建 数据 库 并 建立 数据 表 。 
| (2) 使 用 “select” 查 询 语句 查询 图 书信 息 表 ， 如 图 5.22 中 @ 原 数据 表 所 示 。 
(3) 使 用 “update” 更 新 语句 ， 更 新 数据 表 中 的 数据 ， 其 代码 如 下 : 
update tb_mrbook php set last_date=' 2010-07-11' where id=1; 
当 提 示 符 窗口 出 现 如 图 5.23 所 示 内 容 时 ， 表 示 数 据 更 新 成 功 。 


°° C:\VINDOYS\systen32\cnd.exe — mysql ~uroot -了 
=*2818-87-11’ where id=1; 


图 5.23 ”修改 成 功 提示 


| (5) 通过 SELECT 语句 查询 数据 表 中 内 容 ， 显 示 结 果 如 图 5.23 中 @ 修 改 后 数据 所 示 。 
| (6) 断 开 MySQL 服务 器 连接 ， 关 闭 MySQL 服务 。 


| 技术 要 点 
执行 修改 操作 应 用 的 是 update 命令 ,该 语句 的 语法 格式 如 下 : 
| update 数据 表 名 set column_name = new_valuel,column _name2 = new_value2, ...where condition 
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Ss | 
其 中 , set 子 名 指出 要 修改 的 列 及 其 给 定 的 值 ; where 子 句 是 可 选 的 , 如 果 给 出 该 子 句 ，| 
将 指定 记录 中 哪 一 行 应 该 被 更 新 ， 和 否则 ， 所 有 的 记录 行 都 将 被 更 新 。 | 


实例 091 删除 图 书信 息 表 中 所 有 数据 


实例 说 明 | 

删除 数据 表 中 的 所 有 数据 在 实际 开发 中 是 不 多 见 的 ， 删 除数 据 表 中 的 所 有 数据 意味 着 | 
清空 数据 表 中 的 所 有 信息 ， 如 果 是 操作 上 的 失误 造成 数据 表 中 所 有 信息 丢失 ， 对 于 程序 员 | 
来 说 是 灾难 性 的 。 所 以 对 数据 表 中 信息 的 删除 操作 是 需要 十 分 谨慎 的 。 本 实例 通过 两 种 方 | 
法 实现 删除 图 书信 息 表 中 所 有 数据 ， 运 行 结果 如 图 5.24 和 图 5.25 所 示 。 


YINDOYS\systea32\cad exe - aysec ”回回 加 


te th_mrbook; 


ST C:\WINDOYS\syst 


2\cad. exre 


aysq 加 日 


ws affected (0.00 sec) 9.00 sec》 


elect * from th_mrhooks 


ysql> select * elect * from 
y set 《0.00 sec) npty set (0.00 sec) 


图 5.24 清空 数据 库 图 5.25 删除 所 有 数据 


具体 步骤 如 下 : | 
(1) 启动 MySQL 服务 ,通过 命令 提示 符 窗口 建立 MySQL 连接 ， 新 建 数据 库 和 数据 | 
表 ， 将 数据 表 命 名 为 “tb_mrbook”， 利 用 INSERT 插入 语句 向 数据 表 中 插入 数据 ， 并 通过 | 
SELECT 语句 查询 数据 表 。 | 
(2) 利用 TRUNCATE 语句 ， 清 空 数据 表 中 所 有 数据 ， 其 代码 如 下 : 
truncate tb_mrbook:; 
运行 结果 如 图 5.24 所 示 。 
(3) 利用 DELETE 语句 删除 所 有 数据 ， 其 代码 如 下 : 
delete from tb_mrbook; 
运行 结果 如 图 5.25 所 示 。 
技术 要 点 
(1) 删除 数据 信息 使 用 DELETE 语句 ， 其 语法 如 下 : 


DELETE [LOW_PRIORITY] [QUICK] [IGNORE] FROM tbl name 
[WHERE where_definition] 
[ORDER BY ...] 
[LIMIT row_count] 


该 语句 在 执行 过 程 中 ， 删 除 table_name 表 中 的 记录 ， 如 果 没 有 指定 WHERE 条 件 , 将 
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! 4 
| 删除 所 有 的 记录 ; 如 果 指 定 WHERE 条 件 , 将 按照 指定 的 条 件 进行 删除 。 参数 ORDER BY 
| 表示 按 条 件 排序 ， 参 数 LIMIT row_count 表示 控制 显示 条 数 。 
| (2) 清空 数据 表 信息 使 用 TRUNCATE 语句 ， 其 语法 如 下 : 
仿 站 : TRUNCATE [TABLE] tb name: 


用 于 完全 清空 数据 表 ， 从 逻辑 上 说 ， 该 语句 与 用 于 删除 所 有 行 的 DELETE 语句 等 同 。 
实例 092 ”删除 图 书信 息 表 中 指定 数据 


”实例 说 明 

删除 图 书信 息 表 中 的 所 有 数据 或 者 说 清空 数据 表 的 方法 在 实际 编程 中 是 很 少见 的 ， 

| 般 都 是 指定 删除 一 条 或 几 条 数据 。 本 实例 通过 DELETE ste 
| 指定 数据 ， 运 行 结果 如 图 5.26 所 示 。 

| 实现 过 程 

| 具体 步骤 如 下 ; 

| (1) 启动 MySQL 服务 ， 输 入 命令 连接 MySQL， 创 建 数据 库 和 数据 表 ， 将 数据 表 
| 命名 为 tb_mrbook 并 通过 INSERT 语句 向 数据 表 里 添加 信息 ， 通 过 SELECT 语句 查看 表 
| 信息 。 

| (2) 通过 DELETE 语句 删除 id 等 于 5 的 数据 ， 运 行 结果 如 图 5.27 所 示 。 


e — nysql 一 ul 


WINDOWS\systen32\cad. exe 


| 图 5.26 ”指定 删除 id 等 于 5 的 数据 图 5.27 删除 成 功 提示 
| 技术 要 点 


| 本 实例 的 关键 点 是 WHERE 条 件 句 的 灵活 运用 。WHERE 子 句 是 用 来 选取 需要 检索 的 
| 记录 。 因 为 一 个 表 通 常会 有 数 千 条 记录 ， 在 查询 结果 中 ， 用 户 仅 需 其 中 的 一 部 分 记录 ， 这 
| 时 需要 使 用 WHERE 子 句 指定 一 系列 的 查询 条 件 。 下 面 是 WHERE 子 句 最 简单 的 语法 : 
SELECT< 字 段 列表 > 
FROM< 表 名 > 
WHERE< 条 件 表达 式 > 
| 为 了 满足 多 种 不 同 的 查询 , WHERE 子 句 提供 了 丰富 的 搜索 条 件 , 下 面 将 给 出 WHERE 
| 子 句 常用 的 比较 运算 符 ， 如 表 5.1 所 示 。 
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表 5.1 Where 子 句 的 常用 比较 运算 符 


实例 093 通过 phpMyAdmin 修改 MySQL 用 户 密码 


实例 说 明 


图 形 化 管理 工具 phpMyAdmin 的 出 现 使 MySQL 数据 库 具 有 了 如 Access 和 SQL Server 
数据 库 一 样 简单 而 明了 的 操作 界面 ， 使 程序 员 在 设计 MySQL 数据 库 时 变 得 简单 。 | 
phpMyAdmin 几乎 可 以 实现 操作 数据 库 的 所 有 功能 ， 本 实例 将 演示 如 何 通过 phpMyAdmin | 
修改 MySQL 用 户 密码 。 | 
实现 过 程 
通过 修改 配置 文件 实现 修改 密码 。 | 
(1) 将 下 载 的 phpMyAdmin-x.zip 文件 解压 到 Apache 默认 的 根 目录 下 ， 解 压 后 的 名 | 
称 是 phpMyAdmin-2.x.x.x， 其 中 的 2.x.x.x， 是 版 本 号 。 为 了 方便 使 用 ， 可 以 将 其 重新 命名 | 
为 phpMyAdmin。 
(2) 打开 phpMyAdmin 文件 夹 ， 找 到 配置 文件 config.php， 然 后 使 用 记事 本 或 其 他 编 | 
辑 工具 打开 该 文件 ， 找 到 该 文件 中 的 以 下 内 容 进 行 配置 。 | 
$cfg[PmaAbsoluteUri] = "http://127.0.0.1/phpMyAdmin'; 
以 上 用 于 设置 phppMyAdmin 的 URL， 例 如 ，http:/127.0.0.1/phpMyAdmin。 
$cfg["blowfish_secret] = 'root'; 


更 改 上 述 语 句 中 的 用 户 密码 ， 例 如 ，“root”。 
$cfg['Servers'][$i]['controluser’] = root'; 
S$cfe['Servers'][$il]['controlpass’] = root'; 
$cfg['Servers'][$il[user] = 'root'; 
$cfg['Servers'][$il[password'] = 'root'; 
(3) 完成 以 上 配置 后 保存 该 文件 。 
通过 phpMyAdmin 的 界面 进行 密码 修改 。 | 
(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 单 击 “ 修 改 密码 ”按钮 ， 如 图 5.28 所 示 。 | 
(2) 根据 页 面 提 示 ， 输 入 新 密码 并 确认 密码 ， 如 图 5.29 所 示 。 | 
(3) 单 击 “ 执 行 ”按钮 ， 修 改 MySQL 数据 库 密 码 ， 如 图 5.30 所 示 。 
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图 5.28 ” phpMyAdmin 图 形 化 界面 
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图 5.29 修改 MySQL 数据库 密 码 
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图 5.30 ”完成 密码 修改 


通过 phpMyAdmin 修改 MySQL 用 户 的 密码 可 以 通过 两 种 方法 实现 。 
(1) 直接 通过 phpMyAdmin 的 界面 进行 更 改 。 
.138 。 
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(2) 通过 修改 phpMyAdmin 文件 夹 下 的 配置 文件 config.php 实现 更 改 。 
实例 094 通过 phpMyAdmin 设置 数据 库 、 数 据 表 编码 


实例 说 明 
将 页 面 、 程 序 文件 、 数 据 库 与 数据 表 设 置 成 统一 的 编码 格式 可 以 使 程序 运行 时 不 至 于 | 
出 现 乱 码 。 一 般 情况 下 ， 设 置 页 面 的 编码 格式 由 HTML 中 的 meta 标签 实现 ， 设 置 程序 文 | 
件 的 编码 格式 由 mysql_query0 实 现 ， 设 置 数 据 库 与 数据 表 的 编码 格式 可 以 通过 使 用 | 
phpMyAdmin 实现 。 | 
实 现 过 程 
具体 步骤 如 下 : 


(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 创 建 数据 库 名 称 ， 选 择 编 码 格 式 ， 如 
图 5.31 所 示 。 | 


文件 中 机 本 本 寿 中 收 了 工具 D 一 | 
Qa OW Dm Wm ODS A 
屯 址 @) | 乱 http //1ocwlhost/phpmysdnin/index php?db=db_datsbase00GAtoken-154daf4f9655cef50f3534cue26f9。 于 国 对 到 | 馆 接 | 
PhpRMyAdmin 习 加 服务 器 :1ocalhost - 
_ 避 数据 库 “ 弄 SOL 哮 状 态 ” 同 变 生 。[ 困 字 符 玉 ”如 引擎 、 仿 权 取 “ 蝶 进 程 
介 回 回回 世 各 出 村 入 
» #nysql50# 操作 MySQL 
cdcol (1) 
名 修改 密码 器 服务 器 ; localhost via 
。 database_tell (1) 加 退出 TCPIP 
本 器 服务 器 版 本 : 5.1.41 
© -database008 (56) MySQL localhost 上 协议 版 本 ; 10 
用户; root@localhost 
© -database06 (32) 蕊 新建 数据 库 加 辆 MysoL 字符 集 UTF.8 
© _database23 (3) [db_demo Unicode (utB) 
© -for(l) 网 站 服务 器 
o -om » Apache/2.2.14 (Win32) 
DAY2 mad_ssl2.2.14 
2 bm@ OpenSSUD9 6 
. mod_autoindex_color 
oA PHP/S.3.1 mod_apreq2- 
i 20090110/27.1 
© 直人 mod_per/2.0.4 PerN5 .10.1 
o mbook (3 本 4 turkish ci 忆 》 MySQL 客户 端 版 本 : 51.41 可 
下 厂矿 厂矿 广 阿 条 aeew 


图 5.31 设置 数据 库 编码 格式 
(2) 创建 数据 表 ， 定 义 数 据 表 字段 ， 并 设置 编码 格式 ， 如 图 5.32 所 示 。 
技术 要 点 
通过 phpMyAdmin 设置 数据 库 、 数 据 表 编码 的 操作 方法 十 分 简单 。 在 创建 数据 库 名 称 


时 ， 在 “整理 ”下 拉 列 表 中 选择 需要 设置 的 编码 格式 ;在 创建 数据 表 时 ， 同 样 将 数据 字段 
设置 成 统一 的 编码 格式 。 | 
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图 5.32 设置 字段 编码 格 
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实例 095 ”phpMyAdmin 操作 数据 库 


实例 说 明 


phpMyAdmin 可 以 在 cmd 命令 行 下 实现 对 数据 库 的 操作 ， 而 且 操 作 更 简单 、 直 观 。 本 


实例 通过 phpMyAdmin 实现 对 数据 库 的 创建 和 删除 操作 。 


实现 过 程 


具体 步骤 如 下 : 
(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 根 据 提示 编写 新 建 数据 库 名 称 ， 并 设置 
所 示 。 


数据 库 的 编码 格式 ， 如 图 5.33 
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局 雪 据 库 到 SOL 区 大 坊 ” 国 突 草 “ 辐 学 符 集 页 引 党 益 权限 “ 咏 进 程 
部 导出 本 导入 
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机 TcPnP 
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图 5.33 ”创建 数据 库 
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(2) 单 击 “ 创 建 ” 按 钮 ， 创 建 数据 库 并 自动 选择 创建 的 数据 库 为 当前 数据 库 。 | 
(3) 如 果 数 据 库 已 经 没有 任何 作用 ， 可 以 通过 phpMyAdmin 删除 数据 库 ， 选择 想 要 | 
删除 的 数据 库 ， 单 击 导航 栏 中 的 “删除 ”按钮 ， 根 据 提 示 决 定 是 否 删除 ， 如 图 5.34 所 示 。 


HF PhMJAdmn 至 口 


加 到 
Whi dmv iA | [| 加 


图 5.34 删除 数据 库 
技术 要 点 


切记 在 创建 数据 库 时 ， 一 定 要 设置 数据 库 的 编码 格式 ， 而 且 一 旦 执行 删除 操作 ， 数 据 
库 将 不 能 再 恢复 。 


实例 096 ” phpMyAdmin 操作 数据 表 


实例 说 明 | 
一 般 对 数据 表 的 操作 包括 创建 和 删除 , 下 面 介绍 应 用 phpMyAdmin 图 形 化 工具 实现 数 | 
据 表 的 创建 和 删除 操作 。 | 
实现 过 程 
具体 步骤 如 下 : | 
(1) 登录 到 phpMyAdmin 图 形 化 工具 页 面 ， 创 建 数据 库 ， 选 择 数据 库 编码 格式 ， 单 ， 
击 “ 创 建 ”按钮 ， 根 据 提示 编写 数据 表 名 称 ， 并 填写 想 要 创建 的 数据 表 的 字段 数目 ， 如 | 
图 5.35 所 示 。 | 
(2) 进入 编写 数据 库 字 段 页， 建立 数据 表 结 构 ， 填 写字 段 信息 ， 其 中 包括 字段 名 称 、| 
字段 类 型 、 字 段 长 度 、 是 否 允 许 为 空 等 ， 如 图 5.36 所 示 。 | 
(3) 单 击 “ 保 存 ” 按 钮 ， 完 成 数据 表 的 创建 。 | 
(4) 删除 数据 表 ， 首 先 选择 即将 删除 的 数据 表 名 称 ， 并 进入 数据 表 操作 界面 ， 单 击 | 
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导航 栏 “ 删 除 ”按钮 ， 根 据 提示 删除 数据 表 ， 如 图 5.37 所 示 。 
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图 5.35 创建 数据 表 
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图 5.37 删除 数据 表 
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技术 要 点 


想 要 创建 数据 表 首 先 要 创建 数据 库 ， 当 数据 库 创建 完成 时 自动 选择 已 经 创建 好 的 数据 | 
库 ， 根 据 提示 编写 数据 表 名 称 、 创 建 数据 表 。 而 删除 数据 表 要 先 选 择 想 要 删除 的 表 ， 然后 | 
单 击 “删除 ”按钮 即 可 完成 。 


实例 097 ” phpMyAdmin 操作 数据 


实例 说 明 

对 MySQL 数据 库 数 据 的 操作 包括 插入 数据 、 删 除数 据 、 修 改 数据 和 查询 数据 等 。 本 | 
实例 将 介绍 如 何 通过 phpMyAdmin 图 形 化 管理 工具 完成 上 述 的 操作 。 | 
类 现 过 程 

具体 步骤 如 下 : | 

(1) 查询 数据 信息 : 首先 进入 tb_demo 数据 表 ， 默 认 情 况 下 直接 显示 数据 表 的 信 | 
息 ; 如 果 刚 刚 进行 完 其 他 操作 ， 则 单 击 导 航 栏 “ 浏 览 ” 按 钮 ， 显 示 数 据 表 信 息 ， 如 图 5.38 | 
所 示 。 | 
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图 5.38 查询 数据 信息 


(2) 插入 数据 信息 : 单 击 导航 栏 “ 插 入 ”按钮 ， Sod 
加 ， 单 击 “ 执 行 ”按钮 实现 插入 数据 ， 如 图 5.39 所 示 。 | 
(3) 删除 数据 信息 ， 首先 返回 到 数据 浏览 页 面 ， 如 果 删 除 单条 数据 信息 ， 直 接 单 击 | 
该 条 数据 的 删除 按钮 ， 即 可 完成 单条 数据 的 删除， 如 果 删 除 多 条 数据 信息 ， 可 以 选中 数据 | 
信息 前 端的 复 选 框 ， 然 后 单 击 数据 表 信息 下 端的 “选中 项 删除 ” 按钮， 完成 多 条 信息 删除 ;| 
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Ss 


如 果 想 要 删除 数据 表 中 的 所 有 信息 ， 可 以 单 击 导航 栏 的 “清空 ”按钮 ， 实 现 删除 所 有 数据 
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图 5.39 插入 数据 信息 
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phpiiyAdmin 胃 性 务 器 :localhost ， 司 数据 库 : db_database08 》 加 表 : 由 _demo 
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图 5.40 删除 数据 操作 


改 页 面 ， 完 成 修改 ， 如 图 5.41 和 5.42 所 示 。 
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(4) 修改 数据 信息 : 修改 数据 信息 与 删除 数据 信息 类 似 ， 可 以 分 为 修改 单条 数据 信 
息 和 修改 多 条 数据 信息 。 修 改 单条 数据 信息 直接 单 击 该 条 数据 的 修改 按钮 , 进入 修改 页 面 ， 
实现 修改 。 修 改 多 条 数据 信息 首先 要 选中 复 选 框 ， 然 后 单 击 “ 选 中 项 修改 ”按钮 ， 进 入 修 
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图 5.41 修改 数据 信息 
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加 服务 器 : localhost ， 犀 数据 库 ; db_databaso08 ， 国 表 :由 domo 
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图 5.42 更改 数据 信息 页 

技术 要 点 

phpMyAdmin 图 形 化 管理 工具 操作 数据 的 关键 点 如 下 : 

(1) 查询 数据 信息 : 进入 表 名 为 b_demo (以 tb_demo 为 例 ) 的 数据 表 界面 ， 单 击 导 
航 栏 的 “浏览 ”按钮 。 

(2) 插入 数据 信息 : 单 击 导航 栏 “ 插 入 ”按钮 ， 根 据 提示 插入 信息 。 

(3) 删除 数据 信息 : 单 击 删除 字段 的 关 图 标 ， 删 除 一 行 数据 。 

(4) 修改 数据 信息 : 单 击 修改 字段 的 用 图 标 ， 修 改 一 个 或 多 个 字段 数据 。 
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吾 吾 吾 至 


本 章 读者 可 以 学 到 如 下 实例 : 


实例 098 通过 MySQL 函数 访问 


数据 库 
实例 099 将 数据 以 二 进 制 形 式 上 
传 到 数据 库 


实例 100 查询 日 期 型 数据 

实例 101 查询 字符 囊 

实例 102 使 用 MySQL 存储 过 程 
实现 用 户 注册 

实例 103 ”使 用 MySQL 事务 处 理 
实现 银行 安全 转账 

实例 104 ”避免 输出 中 文字 符 囊 时 
出 现 乱码 

实例 105 ”查询 指定 时 间 段 的 数据 
实例 106 ”查询 从 指定 位 置 的 前 NN 
条 记录 

实例 107 通过 PHP 面向 过 程 实现 
数据 分 页 

实例 108 ”通过 PHP 面向 对 象 实现 
数据 分 页 

实例 109 ”查询 结果 不 显示 重复 记录 
实例 110 ”Delete 语句 删除 图 书信 息 
实例 111 对 统计 结果 进行 排序 
实例 112 使 用 select 子 句 进行 多 
表 查 询 
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吾 吾 吾 至 
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实例 113 合并 多 个 结果 集 

实例 114 简单 的 庶 套 查询 

实例 115 用 in 查询 表 中 的 记录 信息 
实例 116 使 用 聚集 函数 sum() 对 学 生成 
绩 进行 汇总 

实例 117 使 用 聚集 函数 avg 求学 生 的 
平均 成 绩 

实例 118 使 用 聚集 函数 min0 求 利润 最 
少 的 商品 

实例 119 使 用 聚集 函数 max() 求 销售 利 
润 最 高 的 商品 

实例 120 使 用 聚集 函数 countO 求 利润 
大 于 某 值 的 数据 

实例 121 多 表 联 合 查 询 

实例 122 ”left outer join 查询 

实例 123 ”right outer join 查询 

实例 124 利用 transform 分 析 数 据 
实例 125 使 用 格式 化 函数 转换 查询 条 
件 的 数据 类 型 

实例 126 在 查询 中 使 用 日 期 函数 

实例 127 一 般 搜 索 

实例 128 ”高 级 搜索 

实例 129 ”程序 员 搜 索引 擎 
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实例 098 通过 MySQL 函数 访问 数据 库 


( 实例 位 置 : 配套 资源 \SL\06\098 ) 


实例 说 明 


本 实例 讲解 通过 PHP 中 提供 的 MySQL 函数 来 访问 MySQL 数据 库 。 这 里 以 开发 一 个 
电子 商务 网 站 为 背景 ， 通 过 MySQL 函数 实现 与 MySQL 数据 库 的 连接 ， 然 后 读 取 MySQL ， 


数据 库 中 的 图 书 商 品 信息 ,并 且 将 图 书 产品 信息 输出 到 页 面 中 。 其 运行 结果 如 图 6.1 所 示 。 | 
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图 6.1 通过 MySQL 函数 访问 数据 库 


现 过 程 
具体 步骤 如 下 : 


(1) 首先 创建 连接 数据 库 的 conn.php 文件 。 然后 将 该 文件 存储 在 根 目录 下 的 conn 文 | 


件 夹 中 。 将 连接 数据 库 文件 单独 提出 的 目的 是 为 了 日 后 维护 方便 ， 同时 还 可 避免 在 其 他 需 | 


要 连接 数据 库 的 页 面 中 编写 重复 的 代码 ， 这 样 如 果 某 个 页 面 需要 连接 数据 库 ， 只 需 应 用 | | 


include、require 或 include_once 等 语句 调用 conn.php 文件 即 可 。 


连接 数据 库 首先 应 用 的 是 mysql_ connectO 函 数 获取 与 MySQL 服务 器 的 连接 ， 返回 一 | 


个 标识 符 ， 然 后 应 用 mysql select_db0 函 数 连 接 指定 数据 库 (db_database06)， 最 后 应 用 | 
mysql_query0 函 数 定义 输出 数据 的 编码 格式 为 GB2312， 这 样 可 以 避免 在 输出 中 文字 符 .| 
时 出 现 乱码 的 问题 。conn.php 文件 的 代码 如 下 : 


<?php 
$conn=mysql_connect(localhost,root,111) or die(' 连 接 失败 ! 'mysql_errorO): 
if(mysql_select_db('db_database06'.$conn)) 
echo*. 
else 
echo ("数据 库 选择 失败 :' . mysql_error0); 
mysql_query("set names gb2312"); 
> 
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(2) 创建 index.php 文件 ， 输 出 电子 商务 网 站 中 的 图 书 产品 信息 。 首 先 应 用 include_once 


语句 调用 conn.php 文件 , 实现 与 数据 库 的 连接 , 然后 应 用 mysql_query0 函 数 执行 查询 语句 ， 
查询 出 数据 库 中 的 图 书 产 品 信 息 ， 接 着 应 用 mysql_fetch_array0 函 数 将 结果 集 以 数组 的 形 
式 返回 ， 最 后 应 用 while 循环 语句 ， 循 环 输出 结果 集中 的 数据 。 其 关键 代码 如 下 : 


<?php 

$result = mysql query("select * from tb mrbook".$conn); /执行 SQL 指令 

while($myrow = mysql fetch array($result)){ // 配 合 while 输出 数据 库 中 的 数据 
?> 

<tr> 


<td align="lefi" bgcolor="#F FFFFF">&nbsp;<?php echo $myrow[bookname];?></td> 
<td align="center" bgcolor="#F FFFFF"><?php echo $myrow[price]:?></td> 
<td align="lefi" bgcolor="#FFFFFF">&nbsp;<?php echo $myrow[synopsis];?></td> 
<td align="center" bgcolor="# FFFFF"><?php echo $myrow[Maker]:?></td> 
</tr> 
<2php 
} 


> 
技术 要 点 


本 实例 主要 应 用 PHP 中 提供 的 MySQL 数据 库 函 数 ， 分 别 是 mysql_connect()、 
mysql_select_db()、mysql query()、mysql fetch array() 函 数 。 
(1) mysql_connect0 函 数 ， 打 开 一 个 到 MySQL 服务 器 的 连接 。 如 果 成 功 则 返回 一 个 
MySQL 连接 标识 ， 失 败 则 返回 false。 


resource Imysql_connect ( [string server [, string username [， string password [, bool new_link [, int 
client flags]]]]] ) 


mysql_connect(0) 函 数 的 参数 说 明 如 表 6.1 所 示 。 
表 6.1 mysql_connect() 函 数 的 参数 说 明 


参 数 说 明 
MySQL 服务 器 。 可 以 包括 端口 号 ， 如 "hostname:port"， 或 者 到 本 地 套 接 字 的 路 径 ， 如 对 
SeIVeT 于 localhost 的 ":/path/to/socket"。 如 果 PHP 指令 mysql.default host 未 定义 (默认 情况 )， 
则 默认 值 是 'localhost:3306' 


Usemame 用 户 名 。 默 认 值 是 服务 器 进程 所 有 者 的 用 户 名 
password, 密码 。 默 认 值 是 空 密码 

如 果 用 同样 的 参数 第 二 次 调用 mysql_connect0 函 数 , 将 不 会 建立 新 连接 , 而 将 返回 已 经 
new_link 打开 的 连接 标识 。 参 数 new_link 改变 此 行为 并 使 mysql_connect0 函 数 总 是 打开 新 的 连 
接 ， 甚 至 当 mysql_ connectO 函 数 曾 在 前 面 被 用 同样 的 参数 调用 过 

client flags 参数 可 以 是 以 下 常量 的 组 合 : MYSQL_CLIENT SSL，MYSQL_ CLIENT 


COMPRESS, MYSQL CLIENT IGNORE SPACE 或 MYSQL CLIENT INTERACTIVE 


client flags 
(2) mysql_select_db0) 函 数 , 选择 MySQL 数据 库 。 如 果 成 功 返 回 true, 失败 返回 false。 
bool mysql _select db ( string database_name [. resource link identifier] ) 
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mysql_select_db() 函 数 设 定 与 指定 的 连接 标识 符 所 关联 的 服务 器 上 的 当前 激活 数据 | 
库 。 如 果 没 有 指定 连接 标识 符 ， 则 使 用 上 一 个 打开 的 连接 。 如 果 没 有 打开 的 连接 ， 本 函数 | 
将 无 参数 调用 mysql_connect0 函 数 来 尝试 打开 一 个 并 使 用 。 其 后 的 每 个 mysql_query0 函 数 ， 
调用 都 会 作用 于 活动 数据 库 。 | 
(3) mysql_ query0 函 数 ， 向 与 指定 的 连接 标识 符 关 联 的 服务 器 中 的 当前 活动 数据 库 | 

发 送 一 条 MySQL 查询 。 
resource mysql_query ( string query [, resource link identifier] ) 


参数 query 为 字符 串 类 型 ， 指 定 传 入 的 SQL 指令 ; 参数 link_identfier 为 资源 类 型 ， 传 
入 的 是 由 mysql_connect0 函 数 或 mysql_pconnect0 函 数 返回 的 连接 号 。 如 果 省 略 该 参数 ， | 
则 会 使 用 最 后 一 个 打开 的 MySQL 数据 库 连 接 。 


脚下 留神 : 
查询 字符 串 不 应 以 分 号 结束 。 
(4) mysql fetch array0 函 数 ， 返 回 根 据 从 结果 集 获取 的 行 生 成 的 数组 ， 如 果 没 有 更 
多 行 则 返回 false。 | 
array mysql_fetch array ( Tesource result [, int result_type] ) 
mysql_fetch_array0 函 数 的 参数 说 明 如 表 6.2 所 示 。 
表 6.2 mysql_fetch_array() 函 数 的 参数 说 明 


参数 说 了 明 

result 资源 类 型 的 参数 ， 要 传 入 的 是 由 mysql query0 函 数 返 回 的 “数据 指针 >? 
可 选 参数 ,整数 型 参数 ,要 传 入 的 是 MYSQL_ASSOC、MYSQL NUM、MYSQL BOTH 
3 种 由 PHP 定义 好 的 常数 之 一 ， 默 认 值 是 MYSQL BOTH 

result_type 用 MYSQL_ASSOC 只 得 到 关联 索引 (相当 于 mysql_fetch_assocO 函 数 ) 
用 MYSQL NUM 只 得 到 数字 索引 (相当 于 mysql_fetch_row0 函 数 ) 
用 MYSQL BOTH 将 得 到 一 个 同时 包含 关联 和 数字 索引 的 数组 

多 学 两 招 : 


本 函数 返回 的 字段 名 是 区 分 大 小 写 的 。 


实例 099 将 数据 以 二 进 制 形 式 上 传 到 数据 库 


( 实例 位 置 : 配套 资源 \SL\06\099 ) 


实例 说 明 

在 进行 网 站 开发 的 过 程 中 , 有 一 个 问题 是 必须 要 考虑 到 的 , 即 网 站 是 否 支持 文件 上 传 的 | 

功能 ?如 果 支 持 应 该 将 文件 存储 在 什么 地 方 ? 是 存储 在 服务 器 中 ， 还 是 存储 在 数据 库 中 ? ”| 
具体 将 数据 存储 在 什么 地 方 ， 应 该 根据 实际 情况 具体 问题 具体 分 析 ， 如 考虑 文件 的 大 | 
149. Le 
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| 小 、 类 型 等 因素 。 在 电子 商务 网 站 中 ， 每 种 商品 在 展示 的 过 程 中 都 应 该 有 效果 图 ， 而 这 个 


效果 图 的 大 小 基本 不 会 超过 SMB， 类 型 为 bmp、jpg 或 者 gif。 对 于 这 样 的 文件 ， 我 们 就 可 

| 以 将 其 存储 到 数据 库 中 。 
| 本 实例 将 以 电子 商务 网 站 的 商品 效果 图 的 上 传 为 例 ， 讲 解 如 何 将 图 片 以 二 进 制 的 形 
| 式 存储 到 MySQL 数据 库 中 ， 并 且 查看 数据 库 中 存储 的 二 进 制 格式 的 图 片 ， 其 运行 结果 如 


WE 图 62 所 示 。 
| rk 


pn ee 


图 6.2 将 数据 以 二 进 制 形式 上 传 到 数据 库 中 


| 实现 过 程 


具体 步骤 如 下 : 
| (1) 创建 index.php 文件 ， 添 加 表单 ， 设 置 表 单元 素 ， 通 过 post 方法 将 图 书 产品 的 信 
| 息 提 交 到 index_okphp 文件 中 ， 同 时 编写 JavaScript 脚本 对 表单 中 提交 的 元 素 进行 判断 。 


| 其 关键 代码 如 下 : 


<script language="javascript"> 
function check_form(form){ 
if(form.bookname.value—""){ 
alert(" 图 书 名 称 不 能 为 空 11"); 
form.bookname.selectO; 
return(false); 


} 
if(form.price.value—""){ 
alert(" 图 书 价格 不 能 为 空 !1"); 
form.price.select():; 
return(false); 
} 
if(form.cover.value—""){ 
alert(" 图 书 封 面 不 能 为 空 !1"); 
form.cover.selectO; 
return(false); 
} 
return(true); 
| ) 
> . 150 


第 0 章 PHP 数据 库 编程 § 


Ss | 
</script> | 
<form name="form" method="post" action="index_ok.php" onsubmit="return check form(this)"> | 

<tr> 


<td height="36" align="right" bgcolor="#EFFFFF"> 图 书简 介 : </td> 
<td colspan="3" bgcolor="#FFFFFF"> 
<textarea name="synopsis" cols="35" rows="5" id="synopsis"></textarea></td> 
</tr> 
<tr> 
<td height="36" align="right" bgcolor="#EFFFFF"> 封 面 预 览 : </td> 
<td colspan="3" bgcolor="#FFFFFF"><input name="cover" type="file" id="cover" size="30"> 
<span class="STYLE1">*</span></td> | 


</tr> 
<tr> | 
<td height="36" colspan="4" align="center" bgcolor="#FFFFFF"> 
<input type="submit" name="Submit" value=" 提 交 "></td> 
</tr> 
</form> 


(2) 创建 连接 数据 库 的 conn.php 文件 。 

(3) 创建 index_ok.php 文件 。 首 先 通 过 include 语句 调用 连接 数据 库 的 conn.php 文件 ， 
然后 通过 $_POST[] 方 法 获取 表单 中 提交 的 数据 ， 最 后 编写 insert 语句 将 表单 中 提交 的 数据 
添加 到 指定 的 数据 表 中 。 其 关键 代码 如 下 : 


<2php 
header("Content-Type:text/html: charset=utf-8"); // 设 置 编 码 格式 
include("conn/conn.php"): // 包 含 数 据 库 连 接 文 件 


iflisset($_POST["Submit"]){ 
$bookname=$_ POST["bookname"]; 
$price=$_ POST["price"]; 
$maker=$_ POST["maker"]; 
SissuDate=$_POST["issuDate"]; 
$publisher=$_ POST["publisher"]; 
$synopsis=$_ POST["synopsis"]; 
$cover=$_FILES["cover"]["name"]: 1/ 获取 上 传 文件 名 称 
$cover_type=strstr($cover,"."); 1/ 获取 从 "." 到 最 后 的 字符 
if($cover type != ".jpg" && $cover type != ".gif' && $cover type != ".JPG" && $cover type != 
".GIF" && $cover type !=".bmp" && $cover type !(=".BMP"){  // 判 断 图 片 的 格式 
echo "<script>alert(' 封 面 图 片 格式 不 正确 ， 请 进行 处 理 后 再 上 传 ! ); window.location.hre 人 = | 
‘index.php';</script>"; 
}else{ 
$fp=fopen($_FILES['cover]['tmp_name"],"rb"); 。// 以 二 进 制 格式 打开 文件 
Simage=addslashes(fread($fp,filesize($_ FILES['cover'"]['tmp_name']))); // 读 取 文件 | 
$sql="insert into tb_book(bookname.price.makerissuDate.publishersynopsis,cover)values 
(‘$bookname','$price''$maker','$issuDate','$publisher','$synopsis','$image)": /执行 添加 操作 | 
Sresult=mysql_query($sql,$conn); | 
if($result—true) { | 
echo "文件 上 传 成 功 !1"; | 
echo "<meta http-equiv=\"refresh\" content=\"30 url=index.php\">"; | 
}else{ | 
echo "上 传 失 败 11"; | 
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echo "<meta http-equiv=\"refresh\" content=\"30 url=index.php\">"; 


on 后 

MNote 

| 本 实例 主要 应 用 表单 中 的 文件 域 提交 图 片 文件 。 表 单 中 的 文件 域 代码 格式 如 下 : 
| <input name="cover" type="file" id="cover" size="30"> 
| type 指定 表单 元 素 的 类 型 为 文件 域 ; name 指定 表单 元 素 的 名 称 ; size 指定 表单 元 素 的 
| 大 小 。 
| 通过 $_POST[] 方 法 获取 表单 中 提交 的 数据 ， 并 应 用 insert 语句 将 表单 中 的 数据 添加 到 
， 数 据 表 中 。Insert 语句 的 语法 格式 如 下 : 

| Insert into table_ name (column_ name,column name?2, ... ) values (valuel, value2, ... ) 

参数 说 明 : 

table name: 数据 表 的 名 称 。 

回 column name: 数据 表 中 字段 的 名 称 。 

回 “ valuel: 表单 提交 的 变量 。 


脚下 留神 : 


| 在 Insert 语 名 中，column name 与 Valuel 一 定 要 相互 对 应 ; column name 与 数据 表 中 
| 的 字段 也 要 相互 对 应 。 
实例 100 查询 日 期 型 数据 
( 实例 位 置 : 配套 资源 \SL\06\100 ) 
| 实例 说 明 


| 对 日 期 型 数据 进行 查询 在 商业 网 站 中 得 到 了 广泛 的 应 用 ， 例 如 ， 查 询 某 范围 员工 的 出 
| 生日 期 、 商 品 的 进货 时 间 等 。 本 实例 将 在 图 书信 息 表 中 查询 图 书 出 版 日 期 为 “2010-07-19” 
| 的 图 书信 息 ， 运 行 本 实例 ， 如 图 6.3 所 示 。 


替 多 日期 型 区 所 


书 名 日 其 

《PHP 范 例 大 全 》 2010-07-19 
《JAVA 范 例 大 全 》 2010-07-19 
《YB 范例 大 全 》 2010-07-19 
《C++ 范例 大 全 》 2010-07-19 


| 图 6.3 查询 日 期 型 数据 
J 15 
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实现 过 程 | 
创建 index.php 文件 ， 连 接 MySQL 数据 库 ， 当 单 击 显示 数据 按钮 时 ， 程序 会 自动 显示 
出 版 日 期 在 “2010-07-19” 这 一 天 的 所 有 图 书 。 其 代码 如 下 : | 


<?php 
这 $_ POST[sub]){ 
// 单 击 按钮 


S$conn = mysql_connect("localhost","root","111") or die("connect mysql false"):;// 连 接 MySQL | 
mysql select_db("db_database06",$conn) or die("connect database false"); /连接 数据 库 | 
mysql query("set names utf8"); /设置 编码 格式 
S$rs = mysql_ query("select * from tb demo036 where date ='2010-07-19");// 返 回 结果 集 
7 | 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td | 
background="pic/head.JPG"> 书 名 </td><td background="pic/head.JPG"> 剩余 </td><td background="pic/ | 
head.JPG"> 日 期 </td></tr> | 
<2php 
while($rst = mysql_fetch row($rs){ /循环 输出 结果 | 
echo "<tr><td background=pic/head.JPG'>".$rst[0]."</td><td background=pic/head JPG'> | 
"Srst[1]."</td><td background='pic/head JPG'>" Srst[2]."</td><td background='pic/head JPG'>".$rst[3]."</td> | 
</tr>"; | 


1 
> 
技术 要 点 


不 同 的 数据 库 对 日 期 型 数据 的 查询 是 有 区 别 的 ， 下 面 将 以 几 种 典型 的 数据 库 为 例 讲解 
在 不 同 的 数据 库 中 对 日 期 型 数据 的 查询 方式 。 | 
下 面 以 在 学 生 表 (tb_student) 中 查询 出 生日 期 (birthday) 为 “1998-01-01” 为 例 进 行 | 
讲解 。 | 

(1) MySQL 数据 库 中 对 日 期 型 数据 的 查询 。 
Select * from tb_student where birthday="1998-01-01’ 
(2) SQL Server 数据 库 中 对 日 期 型 数据 进行 查询 。 
select * 人 om tb_student where birthday="1998-01-01' 
(3) Access 数据 库 中 对 日 期 型 数据 进行 查询 。 
select * from tb_student where birthday=#1998-01-01# | 
通过 上 面 3 个 例子 可 以 发 现 ， 在 MySQL 数据 库 和 SQL Server 数据 库 中 实现 对 日 期 型 | 
数据 查询 所 要 查询 的 日 期 应 用 单 引 号 括 起 来 ， 而 在 Access 数据 库 中 使 用 JET SQL 语法 查 | 
询 时 所 查询 的 日 期 应 用 “#” 号 括 起 来 。 | 
本 实例 实现 查询 日 期 型 数据 的 SQL 语句 代码 如 下 : 
select * from tb_demo036 where date ='2010-07-19'; 
查询 tb_demo036 数据 表 中 所 有 时 间 date 等 于 “2010-07-19” 的 数据 。 | 
“59s a 
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实例 101 查询 字符 串 


( 实例 位 置 : 配套 资源 \SL\06\101 ) 


实例 说 明 


| “对 字符 串 进 行 查询 是 项 目 开发 过 程 应 用 几率 最 高 的 查询 ， 并 且 这 种 查询 经 常 与 通配符 
| 配合 使 用 实现 信息 的 匹配 查询 。 运 行 本 实例 ， 如 图 6.4 所 示 。 


书 名 CR 日 其 
《PHP 范 饲 大 全 小 2010-07-19 


图 6.4 查询 字符 串 


| 实现 过 程 
| 创建 index.php 文件 ， 连 接 MySQL 数据 库 ， 显 示 查 询 到 的 图 书信 息 。 其 代码 如 下 : 
<2php 
这 $_POST[sub]){ // 单 击 按钮 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false");// 连 接 MySQL 
mysql_select_db("db_database06",$conn) or die("connect database false"); // 连 接 数 据 库 
mysql_query("set names utf8"): /设置 编码 格式 
/返回 结果 集 
S$rs = mysql_query("select * from tb demo036 where name like '%$ POST[select]%"); 
os 


| <table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head. 
| JPG"> 书 名 </td><td background="pic/head.JPG"> 剩 余 </td><td background="pic/head.JPG"> 日 期 </td></t> 
| <?php 

while($rst = mysql_fetch row($rs){ /循环 输出 
| echo "<tr><td background='pic/head.JPG'>".$rst[0]."</td><td background='pic/head. 
| JPG'>".$rst[1]."</td><td background='pic/head.JPG'>".$rst[2]."</td><td background='pic/head.JPG'>".$rst[3]." 
| </htd></tr>": 


技术 要 点 


| SQL 语句 可 以 对 字符 串 进行 完全 匹配 查找 和 模糊 查找 , 如 果 对 字符 串 进行 匹配 查找 则 
| 直接 用 等 号 作为 查询 条 件 的 连接 谓词 ; 如 果 对 字符 串 进行 模糊 查找 则 用 like 关键 字 作为 连 
| 接 谓 词 。 下 面 将 通过 具体 实例 讲解 如 何 实现 对 字符 串 的 查找 。 

(1) 从 学 生成 绩 表 (tb_score〉 中 查询 名 为 “小 刘 ” 的 学 生 信 息 ， 其 中 学 生 姓名 字段 
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为 sname。 


Select * from tb_score where sname= 一 小 刘 ' 


Sname。 


(2) 从 学 生 表 (tb_student) 中 查询 所 有 姓 “ 刘 ”的 学 生 信息 ， 其 中 学 生 姓名 字段 为 


select * 人 om tb_student where sname like ' 刘 90 
(3) 从 职工 表 (tb_worker) 中 查询 所 有 职务 为 “程序 员 ”的 员工 信息 ， 其 中 员工 职 | 


务 字段 为 zhiwu。 
select * from tb_worker where zhiwu like '% 程 序 员 ' 


(4) 从 图 书信 息 表 (tb_book) 中 查询 所 有 PHP 类 相关 图 书 , 其 中 书 名 字段 为 bookname。 
select * from tb_book where bookname like '"%oPHP?%' 


实例 102 使 用 MySQL 存储 过 程 实现 用 户 注册 


( 实例 位 置 : 配套 资源 \SL\06\102 ) 


实例 说 明 


存储 过 程 是 MySQL5.0 以 后 的 版 本 中 才 支持 的 技术 ,通过 存储 过 程 的 应 用 可 以 提高 系 | 
统 的 运行 效率 。 本 实例 将 向 读者 介绍 MySQL5.0 版 本 中 存储 过 程 的 创建 以 及 PHP 调用 | 
MySQL 存储 过 程 的 方法 。 首 先 在 命令 提示 符 下 创建 存储 过 程 ， 然 后 运行 本 实例 ， 如 图 65 | 
所 示 ， 在 图 中 的 文本 框 中 输入 注册 信息 后 ， 单 击 “ 注 册 ” 按 钮 即 可 将 用 户 的 注册 信息 保存 | 
到 数据 库 中 。 | 


' 丸 在 毕 全 1a 


用 户 注册 
让 


[eeeeee 

Falltsesns 

| 
注册 重 写 


版 权 所 有 吉林 省 明日 科技 有 限 公司 | 未 经 授权 禁止 复制 或 建立 镜像 ! 
Copyright © rningrisoft. com, Al Rights Reservedl 2006 
建议 您 在 大 于 1024*768 的 分 辩 率 下 使 用 


图 6.5 填写 用 户 注册 信息 


具体 步骤 如 下 : 

(1) 本 实例 应 用 存储 过 程 实现 用 户 登录 ， 这 里 首先 创建 数据 表 ， 并 添加 字段 信息 。 
本 实例 中 使 用 的 是 tb_user 表 。 数 据 表 中 的 字段 属性 说 明 如 图 6.6 所 示 。 | 

(2) 接 下 来 创建 存储 过 程 。 首 先 打开 “命令 提示 符 ”， 进 入 到 命令 提示 符 后 ， 在 命令 | 
提示 符 中 依次 编写 如 图 6.7 所 示 的 内 容 。 | 
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加 服务 器 : localhost ， 昌 数据 库 : db_database06 ， 国 表 :tb_user 
加 浏览 。 辽 结构 ,及 sa 万 搜索 也: 黄 入 圈 导 出 ”图 Import_ 颖 操作 


字 委 类 型 整理 屋 性 Null 
ml| intt10) 否 ”关键 宁 
厂 username varchar(50) gb2312_chinese_ci 否 用户 名 
厂 Password varchar(50) gb2312_chinese_ci 否 窗 码 
厂 email varchar(50) gb2312_chinese_ci 否 ”邮箱 
厂 address varchar(80) gb2312_chinese_ci 否 地址 


图 6.6 tb_user 表 的 字段 属性 说 明 


IC:\Docunents and Se gs o sql -uroot -proot 
Melcone to the My: a d with ; or \g. 
MySQL connecti 
version: 5-9 unity-nt-log nunity Edition 


"Ah for help. Type ’\c’ to clear the buffer. 


《in ne varcharC50), in pwd varcharC5 


ssword,enail,address)yvaluesCnv ,pwd,enail,al 


, @ rows affected (8.03 sec) 


图 6.7 创建 存储 过 程 
创建 存储 过 程 的 关键 代码 如 下 : 


人 # 使 用 的 存储 过 程 

delimiter // 

create procedure pro_regs(in nc varchar(50),in pwd varchar(50),in email varchar(50),in address 

varchar(50)) 

begin 

insert into tb_user(username,password,email,address)values(nc.pwd,email,address); 

end; 

/ll 

dh 


(3) 创建 index.php 文件 ， 添 加 表单 ， 设 置 表单 元 素 ， 通 过 post 方法 将 用 户 注 册 信 息 
提交 到 本 页 ， 代 码 如 下 : 
<form name="forml" method="post" action="index.php" onsubmit='"retum chkinput(this)"> 


<tr> 
<td width="150" height="25"” bgcolor="#FFFFFF"><div align="center"> 用户 昵称 : 


</div></td> 
<td width="347" bgcolor="#FFFFFF">&nbsp;<input type="text" name="ne" class="inputcss" 
size="25"></td> 
</t> 
<t> 
<td height="25" bgcolor="#FFFFFF"><div align="center"> 注 册 密 码 : </div></td> 
<td height="25" bgcolor="#FFFFFF">&nbsp;<input type="password" name="pwd" 
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class="inputcss" size="25"></td> 
</tr> 
<tr> | 
<td height="25" col ="2" bgcolor="#FFFFFF"><div ign="center"><input | 
type="submit" name="submit" value=" 注 册 " class="buttoncss">&nbsp:&nbsp:<input type="reset" value=" 重 写 | 
" class="buttoncss"></div></td> 
</tr> 
</form> 


通过 PHP 预定 义 类 mysqli 实现 与 MySQL 数据 库 的 连接 , 并 通过 call 语句 调用 存储 过 | 
程 pro_regs， 将 用 户 注册 的 数据 添加 到 tb_user 数据 表 中 。 其 关键 代码 如 下 : | 


<?php | 
if($_POST[submit]!="") | 
{ 
$conn=new mysqli("localhost","root","111","db_database06"); /连接 数据 库 
$conn->query("set names gb2312"); // 设 置 编 码 格式 
$nc=$ POST[nc]; 1/ 获取 用 户 注册 提交 的 数据 


$pwd=mds($_ POST[pwd]); 
$email=$_ POST[email]; 
$address=$_ POST[address]; | 
if($sql=$conn->query("call pro_reg(".$nc.",".$pwd.",".$email.",".$address.")")){// 调 用 并 执 ， 
行 存储 过 程 
echo "<script>alert( 用 户 注册 成 功 !");</script>"; 
}else{ 
echo "<script>alert( 用 户 注册 失败 1");</script>"; 


技术 要 点 


本 实例 主要 应 用 存储 过 程 实现 用 户 注 册 的 功能 ,其 关键 在 于 存储 过 程 的 创建 MySQL 
存储 过 程 的 语法 如 下 : | 
create procedure proc_name (in parameter integer) 
begin | 
declare variable varchar(20); | 
if parameter=] then | 
set variable="MySQL'; | 
else 
set variable="PHP’; 
end 1f: 
insert into tb (name) values (variable); 
end; | 
MySQL 中 存储 过 程 的 建立 以 关键 字 create procedure 开始 ， 后 面 紧 跟 存 储 过 程 的 名 称 | 
和 参数 。MySQL 的 存储 过 程 名 称 不 区 分 大 小 写 ， 例 如 ，PROCE10 和 proce10 代 表 同 一 存 | 
储 过 程 名 。 存 储 过 程 名 不 能 与 MySQL 数据 库 中 的 内 建 函 数 重 名 。 
。157 。 | 


Pip 经 并 编程 265 全 


可 

存储 过 程 的 参数 一 般 由 三 部 分 组 成 。 第 一 部 分 可 以 是 nm、out 或 inout。in 表示 向 存储 
过 程 中 传 入 参数 ;，out 表示 向 外 传 出 参数 ;inout 表示 定义 的 参数 可 传 入 存储 过 程 并 可 以 被 
存储 过 程 修改 后 传 出 存储 过 程 ， 存 储 过 程 默 认为 传 入 参数 ， 所 以 参数 in 可 以 省 略 。 第 二 部 
分 为 参数 名 。 第 三 部 分 为 参数 的 类 型 ， 该 类 型 为 MySQL 数据 库 中 所 有 可 用 的 字段 类 型 ， 
如 果 有 多 个 参数 ， 参 数 之 间 可 以 用 去 号 进行 分 割 。 

MySQL 存储 过 程 的 语句 块 以 begin 开始, 以 end 结束。 语句 体 中 可 以 包含 变量 的 声明 、 
控制 语句 、SQL 查询 语句 等 。 由 于 存储 过 程 内 部 语句 要 以 分 号 结束 ， 所 以 在 定义 存储 过 程 


| 前 应 将 语句 结束 标志 “;” 更 改 为 其 他 字符 ， 并 且 该 字符 应 该 在 存储 过 程 中 出 现 的 儿 率 也 应 
| 该 较 低 ， 可 以 用 关键 字 delimiter 更 改 ， 例 如 : 


mysql>delimiter // 
存储 过 程 创建 之 后 ， 可 用 如 下 语句 进行 删除 ， 参 数 proc_name 指 存储 过 程 名 。 
drop procedure proc_name 
创建 及 调用 存储 过 程 的 步骤 如 下 : 
(1) MySQL 存储 过 程 是 在 命令 提示 符 下 创建 的 ， 所 以 首先 应 该 打开 “命令 提示 符 ”。 
(2) 进入 “命令 提示 符 ” 后 ， 首 先 应 该 登录 MySQL 数据 库 服务 器 ， 在 命令 提示 符 下 


| 输入 如 下 命令 : 


mysql -u 用 户 名 -p 用 户 密码 
(3) 更 改 语句 结束 符号 ， 本 实例 将 语句 结束 符 更 改 为 “//”， 代 码 如 下 : 


delimiter // 
(4) 创建 存储 过 程 前 应 首先 选择 某 个 数据 库 ， 代 码 如 下 : 
use 数据 库 名 


(5) 创建 存储 过 程 。 
(6) 通过 call 语句 调用 存储 过 程 。 


实例 103 使 用 MySQL 事务 处 理 实现 银行 安全 转账 


( 实例 位 置 : 配套 资源 \SL\06\103 ) 


实例 说 明 


事务 处 理 机 制 在 程序 开发 过 程 中 有 着 非常 重要 的 作用 ， 它 可 以 使 整个 系统 更 加 安全 ， 
例如 ， 在 银行 处 理 转账 业务 时 ， 如 果 A 账户 中 的 金额 刚 被 发 出 ， 而 B 账户 还 没 来 得 及 接 
受 就 发 生 停电 ， 这 会 给 银行 和 个 人 带 来 很 大 的 经 济 损失 。 采 用 事务 处 理 机 制 ， 一 旦 在 转账 
过 程 中 发 生意 外 ， 则 程序 将 回 滨 ， 不 做 任何 处 理 。 

本 实例 设计 了 一 个 模拟 的 银行 转账 系统 ， 并 且 应 用 事务 处 理 机 制 保证 转账 操作 安全 、 
顺利 地 进行 。 运行 本 实例 , 如 图 6.8 所 示 , 在 图 中 的 文本 框 中 输入 要 转 给 B 账户 的 金额 后 ， 
单 击 “ 转 账 ” 按 钮 即 可 实现 转账 。 
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图 6.8 应 用 事务 回 滚 模拟 银行 转账 


实现 过 程 


具体 步骤 如 下 : 
(1) 创建 数据 库 连 接 文 件 conn.php。 这 里 应 用 PHP 中 的 预定 义 类 mysqli 连接 数据 库 ， 
<2php 
$conn=new mysqli("localhost","root","111","db_database06"): 


$conn->query("set names gb2312"):; 
S 


(2) 创建 index.php 文件 ， 读 取 数 据 库 中 的 数据 。 首 先 通过 include 语句 调用 连接 数 
据 库 文件 。 然 后 执行 查询 语句 ， 读 取 并 输出 数据 库 中 的 数据 。 最 后 创建 表单 ， 添 加 文本 杠 
提交 转账 金额 ， 将 数据 提交 到 index_ok.php 页 面 中 。 其 关键 代码 如 下 : 


<2php 
$conn=new mysqli("localhost","root","111","db_database06"); 
$conn->query("set names gb2312"); 
?> 
<form name="form]1" method="post” action="index_ok.php” onsubmit="return chkinput(this)"> 
<table width="300" height="25" border="0" align="center" cellpadding="0" cellspacing="0'> 
<tr> 
<td>A 账户 现 有 金额: <?php echo $info[money]:?>&nbsp: 元 </td> 
</tr> 
</table> 
<table width="300" height="25" border="0" align="center" cellpadding="0" cellspacing="0'> 
<tr> 
<td> 转 给 B 账户 : <input type="text”" name="tob” class="inputcss" size="20"></td> 
</tr> 
</table> 
<table width="300" height="25" border="0" align="center” cellpadding="0" cellspacing="0'> 
<tr> 
<td>B 账户 现 有 金额: <?php echo $infos[money]:?>&nbsp: 元 </td> 
</tr> 
</table> 
<table width="300" height="25" border="0" align="center” cellpadding="0" cellspacing="0'> 
<tr> 
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<td><div align="center’><input type="submir” value= "攻克 ' class="buttoncss’></div></td> 


</tr> 
</table> 
| </form> 
| (3) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 应 用 事务 处 理 机 制 完成 转账 


ee 操作 ， 代 码 如 下 : 


Ra _POST[tob]: 

include_once("conn/conn.php"); 

S$conn->autocommit(false); // 关 闭 自动 提交 

if(!$conn->query("update tb_bank set money=money-"".$tob." where Username='mrsoft")) 
{ 


$conn->rollback(); /实现 事务 回 滚 

人 tb_bank set money=money+".$tob." where usemame=mr) 
ee 

人 /提交 所 有 更 新 语句 


$conn->autocommit(true); 
echo "<script>window.location.href='index.php';</script>"; 
?> 


| 技术 要 点 
| 事务 的 作用 在 服务 器 发 生 错误 或 骨 溃 的 情况 下 确保 数据 库 的 一 致 性 。 事 务 是 一 个 或 一 
| 系列 的 查询 ， 这 些 查 询 要 么 全 部 执行 ， 要 么 全 部 不 执行 。 例 如 ， 银 行 转账 需要 两 个 过 程 来 
| 完成， 首先 需 从 某 个 账户 扣除 一 定金 额 ， 之 后 在 另 一 个 账户 中 增加 相同 的 金额 。 如 果 这 两 
| 141 个 过 程 不 同时 执行 ， 从 第 一 个 账户 中 扣除 金额 后 还 没 来 得 及 增加 第 二 个 账户 的 金 Ra 
| 停电 或 服务 器 崩溃 ， 这 将 给 用 户 和 银行 造成 很 大 的 损失 。 如 果 采 用 事务 处 理 上 述 过 程 
| 使 出 现 上 述 事 故 也 不 会 给 用 户 造成 损失 。 
| 一 个 事务 被 永久 的 写 入 到 数据 库 中 称 事务 提交 ， 将 状态 重 置 到 事务 开始 之 前 的 状态 称 
| 为 事务 回 滚 。 
| 事务 具有 以 下 4 个 特性 : 

(1) 原子 性 : 指 事务 作为 一 个 整体 要 么 完全 执行 ， 要 么 完全 不 执行 。 

(2) 一 致 性 : 指 一 个 事务 必须 能 够 使 数据 处 于 一 致 的 状态 。 

(3) 孤立 性 : 在 事务 完全 完成 之 前 ， 它 们 都 是 孤立 的 。 

(4) 持续 性 : 一 旦 写 入 数据 库 后 ， 事 务必 须 是 永久 和 持续 的 。 

PHP 处 理 MySQL 事务 是 通过 PHP 中 的 预定 义 类 mysqli 来 完成 的 ， 具 体 方法 如 下 : 

| (1) autocommit0): 该 方法 的 参数 为 false 或 tue，false 表示 禁止 自动 提交 查询 ，true 
| 表示 自动 提交 查询 。 
| (2) rollback0: 该 方法 的 作用 是 当 发 生意 外 时 ， 自 动 回 滚 到 事务 开始 之 前 的 状态 。 

(3) commit(): 该 方法 的 作用 是 提交 事务 。 
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在 本 实例 中 应 用 事务 实现 转账 的 代码 如 下 : 


<2php 

$tob=$_ POST[tob]: 

include_once("conn.php"); 

$conn->autocommit(false); 

if(!$conn->query("update tb_zy set money=money-'".$tob." where flag="mrsoft"")) 
{ 


$conn->rollback(); 
} 
if(!$conn->query("update tb_zy set money=money+'".$tob."” where flag='mr")) 
{ 


$conn->rollback(O; 
} 
S$conn->commit(); 
$conn->autocommit(true); 
echo "<script>window.location.href='index.php';</script>"; 
?> 


首先 调用 mysqli 类 的 autocommit0 方 法 关闭 数据 库 的 自动 提交 , 然后 减少 A 账户 一 定 


数量 的 金额 并 判断 查询 是 否 顺 利 执行 ,如 果 在 此 过 程 中 发 生意 外 ， 则 通过 调用 mysqli 类 的 
rollback0 方 法 回 滚 ， 不 做 任何 处 理 ， 反 之 为 B 账户 增加 相同 的 金额 。 最 后 通过 调用 mysqli | 
类 的 commit0 方 法 提交 查询 ， 实 现 转 账 。 | 


实例 104 ”避免 输出 中 文字 符 串 时 出 现 乱 码 


( 实例 位 置 : 配套 资源 \SL\06\104 ) 


实例 说 明 


将 数据 库 中 信息 显示 到 网 页 中 经 常会 遇 到 这 样 的 问题 ， 网 页 中 输出 的 中 文 文字 为 乱 | 


码 。 造 成 问题 的 主要 原因 是 数据 库 中 的 编码 格式 与 页 面 设置 的 编码 格式 不 符 或 者 没有 将 数 | 


二 


dD 


据 信息 统一 为 GBK、GB2312 或 UTF-8。 本 实例 通过 设置 编码 格式 向 用 户 演示 如 何 避 免 给 | 
中文 字符 串 时 出 现 乱 码 ， 运 行 结果 如 图 6.9 所 示 。 | 


PR 村 有 
at ED 
书 名 价格 日 其 
PAP????O0 ??? 伯 cd> 800 2010-07-17 
YB????00 ?3? 伯 td> 8300 2010-07-17 
JAVA??33D0 ?33 伯 5d> 79%0 2010-07-17 
JAVAWE8???3D0 ??? 伯 td> 780 2010-07-17 
.NET???3DI ?3?? 伯 5d> 780 2010-07-17 
C#33??D ??? 伯 td> ‘780 2010-07-17 
[C++33??73DI ?3?? 伯 rd> T780 2010-07-17 


图 6.9 错误 设置 编码 格式 输出 中 文 
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 &% 
| 实现 过 程 

创建 脚本 文件 ， 并 命名 为 index.php。 创 建 form 表单 ， 将 要 设置 的 编码 格式 提交 到 本 
| 页 。 在 本 页 中 连接 服务 器 ， 连 接 指 定 的 数据 库 ， 根 据 form 表单 提交 的 数据 设置 数据 库 的 


全 ~ 编码 格式 ， 然 后 循环 输出 数据 库 中 的 数据 ， 其 代码 如 下 : 
| if($_POST[sub){ // 单 击 “ 确 定 ” 按 钮 


if$_POST[name] 一 "上 |$_POST[name] 一 "输入 编码 格式 "){// 如 果 文本 框 为 空 或 初始 值 
echo "<script>alert(' 文 本 框 内 容 不 正确 ");</script>"; 
}else{ 
| $conn = mysql connect("localhost","root","111") or dir ("connect MySQL false");// 连 接 
| MySQL 数据 库 


mysql_select_db("db_database06",$conn) or die ("connect database false"):// 连 接 数 据 库 
mysql_ query("set names $ POST[name]"); /设置 编码 格式 
S$rs = mysql_ query("select * from tb_demo031"); /返回 结果 集 


| echo "<table width='580px'><tr><td bgcolor=#FF0000>ID</td><td bgcolor=#FF0000'> 
| 书 名 </td><td bgcolor=-#FF0000> 价 格 </td><td bgcolor=#F0000> 日 期 <td></tr>"; 

| while($rst = mysql fetch row($rs){ /循环 输出 

| echo "<tr><td bgcolor='#FF0000'>".$rst[0]."</td><td bgcolor='#FF0000'>".$rst[1]. 
| "</td><td bgcolor=#FF0000'>".$rst[2]."</td><td bgcolor='#FF0000'>".$rst[3]."</td></tr>"; 


| 

| echo "</table>"; 
| } 

} 

| > 

| 技术 要 点 


set 语句 : 用 于 设置 不 同 变量 。 其 语法 如 下 : 


SET variable_assignment [, variable_assignment] ... 
variable_assignment: 
User_var_name = expr 
|[GLOBAL | SESSION] system var_ name = expr 
|@@l[global. | session.]system var_name = expr 


本 实例 通过 set 语句 设置 页 面 的 编码 格式 ， 其 代码 如 下 : 


set names $ POST[name]: 


实例 105 查询 指定 时 间 段 的 数据 


( 实例 位 置 : 配套 资源 \SL\06\105 ) 


| 实例 说 明 
| 在 图 书 管理 系统 中 ， 经 常 需要 查询 指定 出 版 日 期 范围 内 的 图 书 情况 。 运 行 本 实例 ， 如 
| 图 6.10 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 日 期 范围 ， 然 后 单 击 “ 查 看 ”按钮 即 可 实现 查找 
| 该 日 期 范围 内 的 所 有 图 书信 息 。 
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障 入 结束 日 期 


日 期 

2010-01-01 
2010-03-11 
2010-04-11 
2010-04-22 
2010-05-17 


图 6.10 查询 指定 时 间 段 的 数据 
实现 过 程 
创建 mdex.php 文件 ， 启 动 MySQL 服务 并 连接 MySQL 数据 库 。 当 单 击 “ 查 看 ”按钮 
时 ， 显 示 指 定时 间 段 的 数据 。 代 码 如 下 : 
<?php 
if($_POST[sub]) { // 单 击 “ 查 看 ”按钮 
/判断 文本 框 信息 
这 $_ POST[textl] == "" | $_POST[textl] 一 "输入 开始 日 期 " || $_POST[textl 一" | 
$_POST[text] 一 "输入 结束 日 期 "){ 
echo "<script>alert(' 请 输入 日 期 );</script>"; //JavaScript 提示 
}else{ 
// 验 证 日 期 格式 的 正则 表达 式 
if(preg_match("/([0-9]{3}[1-9][0-9]{2}[1-9J[0-9]{1}[1-9]J[0-9]{2}I[1-9]J[0-9]{3})-(C(O[13578]I1[0-2] 
)-(O[1-9]I[12][0-9]I3[01]))IC(OL469]l11)-(O[1-9]I[12][0-9]l30))I(02-(O[1-9JI[1][0-9]I2[0-8])))/",$_POST[text)){ 


// 连 接 MySQL 
$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); 
// 连 接 MySQL 数据 库 
mysql_select_db("db_database06",$conn) or die("connect database false"); 
mysql_query("set names utf8"): /设置 编码 格式 
$rss = mysql query("select * from tb _ demo047 where date between '$ POST 
[textl] and'$_ POST[textl' order by date"); /返回 结果 集 


echo'<table width="580px"><tr><td ”background="pic/head.JPG">ID</td><td 
background="pic/head.JPG"> 书 名 </td><td background="pic/head.JPG"> 价 格 </td><td background="pic/head 
JPG"> 日 期 <td></tr>'; 

while($rst = mysql fetch array($rss){ 1/ 循环 输出 结果 

> 
<tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head.JPG"> 

<2php echo $rst[1]:?></td><td background="pic/head.JPG"><?php echo S$rst[2]:?></td><td background="pic/ 
head.JPG"><?php echo $rst[3]:?></td></tr> 


<?php 
} 
jelse{ 
/JavaScript 提示 信息 
echo "<script>alert(' 日 期 格式 错误 ! 正确 格式 为 : xxxx-xx-xx");</script>"; 
} 
} 
} 
> 
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| 在 SQL 语句 中 实现 对 指定 范围 内 的 数据 进行 查找 可 以 通过 以 下 两 种 方式 实现 : 
全 办 | 第 一 可 以 通过 关键 字 between...and... 实 现 ， 语 法 格式 如 下 : 
SS select 要 查找 的 字段 from 表 名 where 字段 名 between 初始 值 and 终止 值 
第 二 种 方式 可 以 通过 比较 运算 符 实现 ， 语 法 格式 如 下 : 
select 要 查找 的 字段 from 表 名 where 字段 名 > 初始 值 and 字段 名 < 终止 值 


实例 106 查询 从 指定 位 置 的 前 N 条 记录 


| ( 实例 位 置 配套 资源 \SL\06\106 ) 


| 实例 说 明 

| 查询 从 指定 位 置 开 始 显示 N 条 记录 ， 这 也 是 PHP 实现 分 页 显示 的 原理 。 本 实例 将 应 
| 用 MySQL 中 的 limit 关键 字 ， 完 成 从 指定 位 置 开 始 显 示 N 条 记录 的 查询 操作 。 从 第 4 条 
;记录 开始 ， 查 询 两 条 数据 ， 其 运行 结果 如 图 6.11 所 示 。 


价格 日 期 
7 2010-07-17 
7 阮 2010-07-17 


图 6.11 查询 从 指定 位 置 的 N 条 记录 
实现 过 程 
创建 index.php 文件 ， 编 写 网 页 框架 ， 启 动 MySQL 服务 器 ， 连 接 MySQL 数据 库 ， 当 
单 击 “查看 ”按钮 时 ， 显 示 指定 位 置 的 N 条 记录 。 代 码 如 下 : 


| if($_POST[sub]){ // 单 击 按钮 

| /| 判断 文本 框 信息 

| if($_POST[text] 一 "| $_ POST[text 一 "输入 图 书 名 称 "外 $_POST[textl] 一 "" || $_ POST[textl] 
| 二 "输入 查询 条 数 "){ 

| echo "<script>alert( 输 入 图 书 名 ");</script>"; //JavaScript 提示 

| j}else{ 

| ifpreg_match("d/".$_POST[textD)){ /正则 表达 式 验 证 

| if(preg_ match("N\d/",$ POST[text1]){ // 正 则 表达 式 验 证 

| /连接 MySQL 

| $conn = Imysql connect("localhost","root","111") or die("connect mysql false"); 
| /连接 MySQL 服务 器 

| Inysql_select db("db_database06".$conn) or die("connect database false ); 

| Imysql_ query("set names utf8"): /设置 编码 格式 

| /返回 结果 集 
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Srss = mysql query("select * from tb demo031 limit $ POST[textl], $ POST ' 
[text]"); | 
echo'<table width="580px"><tr><td 。 background="pic/head.JPG">ID</td><td | 
background="pic/head.JPG"> 书 名 </td><td ”background="pic/head.JPG"> 价 格 </td><td background="pic/ | 
headJPG"> 日 期 <tq></tr>; | 

while($rst = mysql fetch array($rss){ // 循 环 输出 结果 | 


JPG"><?php echo $rst[1];?></td><td background="pic/head.JPG"><?php echo $rst[2]:?></td><td background= 


?> 
<tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head. 
pic/head.JPG"><?php echo $rst[3]:2></td></tr> | 


<2?php 
} 
jelse{ 
echo "<script>alert( 输 入 的 不 是 一 个 数字 );</script>": /JavaScript 提示 
} 
}else{ 
echo "<script>alert(' 输 入 的 不 是 一 个 数字 ');</script>"; //JavaScript 提示 
} 
} 
?> 
指点 迷津 : 


本 实例 在 运行 时 ， 用 户 设 定 从 第 2 条 开始 输出 ， 而 显示 数据 时 是 从 第 3 条 开始 ， 出 现 
这 种 情况 的 原因 是 数据 信息 ID 是 从 0 开始 计算 的 。 


技术 要 点 
实现 从 指定 位 置 开始 查询 满足 条 件 的 n 条 记录 , 主要 应 用 MySQL 的 扩展 关键 字 limit， 
该 关键 字 的 使 用 格式 如 下 : 
select 要 查询 的 字段 from 表 名 where 查询 的 条 件 limit 满足 条 件 的 起 始 位 置 ， 记 录 的 个 数 
关键 字 limit 后 有 两 个 参数 : 第 一 个 参数 用 于 指定 要 满足 条 件 记录 的 起 始 位 置 ， 第 二 
个 参数 指定 查询 结果 中 满足 条 件 的 记录 个 数 。 
本 实例 实现 查询 指定 位 置 的 N 条 记录 的 SQL 语句 代码 如 下 : 
select * from tb demo031 limit$ POST[textl],$_POST[text]: 


实例 107 通过 PHP 面向 过 程 实现 数据 分 页 | 


( 实例 位 置 : 配套 资源 \SL\06\107 视频 位 置 配套 资源 \SP\06\107 ) 


实例 说 明 | 


对 于 数据 库 中 存储 的 大 量 的 数据 ， 如 果 想 要 进行 输出 ， 最 佳 的 方法 就 是 使 用 分 页 。 通 
过 分 页 输出 数据 ， 可 以 保持 页 面 整 洁 ， 同 时 提高 数据 的 浏览 速度 。 


“1165 


人 Pp 经 各 编程 265 人 


本 实例 中 将 介绍 如 何 通过 PHP 面向 过 程 编程 实现 数据 的 分 页 输出 运行 结果 如 图 6.12 


所 示 。 


两 有 考题 ” 参 品 桌 特价 末 品 。 风 的 推 车 几 户 等 程 “可 间 玛 词 ” 窟 记名 


EROEEEEEDE3 


二 明 昌 电子 机 大 开业 了 
让 PPM 

二 日 电 了 间 红 呈 太 开 -了 : 3 ss: 
es 从 本子 耻 ， 顺 至， 全 大 高 


1 博得 本 CE 页: 要 8 下 -RE SR 23 | 内 
第 ;位 攻关 二 贡 钊 
天 人 50 下 记 下 电话 


图 6.12 分 页 输出 数据 库 中 数据 


在 本 实例 中 综合 了 上 下 分 页 和 跳 转 分 页 的 功能 。 上 下 分 页 以 当前 页 码 为 基础 ， 实 现 上 


一 页 和 下 一 页 的 跳 转 ， 并 且 输 出 上 一 页 的 最 后 一 条 数据 和 下 一 页 的 第 一 条 数据 的 内 容 ; 而 
| 跳 转 分 页 实现 以 十 页 为 一 个 单位 ， 实 现 上 10 页 和 下 10 页 的 跳 转 ， 并 且 可 以 在 当前 页 显示 
| 的 10 个 超 链接 中 任意 跳 转 。 


| 实现 过 程 


有 具体 步骤 如 下 : 
| (1) 创 建 数据 库 连 接 文件 conn.php。 通 过 PHP 中 的 MySQL 函数 连接 MySQL 数据 库 ， 
| 代码 如 下 : 
| <9php 


$id=mysql_connect("localhost","root","111")or dir(' 连 接 失 败 :' . mysql]_error0); 
这 mysql_select_ db("db_database06",$id)) 

Rom 

else 

echo (连接 失败 :' . mysql_errorO): 

mysql_query("set names gb2312"); 

和 


(2) 创建 mdex.php 文件 ， 实 现 分 页 输出 数据 库 中 的 数据 。 


首先 ， 调 用 连接 数据 库 文件 ， 初 始 化 分 页 变量 。 代 码 如 下 : 


<2php 
include_once("conn/conn.php"); 
if($_GET[page]—"") 


上 
$_GET[pagel=1; 
1 
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if($_GET[Iink type]—"") 


{ 


$_GET[link type]=0;}; 


?> 


然后 ， 读 取 数 据 库 中 的 数据 ， 应 用 分 栏 方法 输出 数据 库 中 的 数据 ， 并 且 定义 数据 分 页 | 


输出 的 变量 。 其 关键 代码 如 下 : 


<?php 
$query_1 =mysql query ( "select * from tb_book" ); // 获 取 数据 库 中 总 的 记录 数 
让 (mysql num rows ($query 1)<=0){ // 刊 断 值 是 否 为 空 
> 
<tr><td colspan=”2"” align="center 祖 没有 数据 ! </td></tr> 
<2php 
}else { 
$number = 0; // 定 义 变量 


if($_GET [page]) { 


<tr> 
<2php 


<?php 


> 


Spage size = 2; // 每 页 显示 两 条 数据 
$query = "select count(*) as total from tb_book"; 
$result = mysql_query ( $query ); 
$message_count = mysql result ( $result, 0, "total" ); /统计 总 的 记录 数 
$page_count = ceil ($message count/ $page_ size ); /计算 总 共有 几 页 
$offset = ($_GET [page] - 1) * $page size; // 获 取 当 前 页 的 起 始 页 
$query 2 = mysql query ( "select * from tb_book limit $offset Spage_size" ); 
while ( $myrow_2 = mysql fetch array ( $query 2 ) ){ // 循 环 输出 

if (($number % 2)— 0) { // 取 模 

3 


} 


<td colspan=”2” align="center”><!-- 输 出 数据 库 中 数据 ， 省 略 了 部 分 代码 --></td> 


if (($number % 2) !=0) { // 取 模 
> 
$number ++; // 增 加 变量 值 


接着 ， 以 当前 页 码 为 基础 ， 实 现 上 一 页 和 下 一 页 的 跳 转 ， 输 出 上 一 页 的 最 后 一 条 数据 
和 下 一 页 的 第 一 条 数据 。 其 关键 代码 如 下 : 
<td width="70" height="22" align="center" bgcolor="#FFFFFF"><spanclass="STYLE2"> 图 书 : 


<?php 


echo $message_count': 
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CD 
次 、 
从 
?> 部 &nbsp; </span></td> 
<td width="139" align="center" bgcolor="#FFFFFF"> 上 一 部 : <a 
href="index.php?page=<?php 
if($_ GET [page]—""or$ GET [page] — 1){ // 判 断 如 果 分 页 变量 值 为 空 或 小 于 1 
echo 1; // 输 出 1 
}else{ 
echo ceil ( ($_GET [page] * 2 - 2) /2 );// 否 则 ,根据 每 页 中 显示 两 条 记录 ,计算 出 上 一 页 page 
的 值 
> 
> 
<?php 
S$page 3=($_ GET [page]-2)*2+1; /计算 出 上 一 页 中 两 条 记录 的 结束 值 
让 ($page 3 <= 0) { /如 果 $page 3 的 值 小 于 等 于 0， 则 输出 0 
$page 3=0; 
$query_ 3 =mysql query ( "select * from tb_book limit $page 3,1" ); 
$myrow_3 = mysql_fetch array ( $query_3 ); 
echo $myrow_3 [bookname]: // 输 出 上 一 页 中 的 最 后 一 条 数据 
六 
</a></td> 
<td width="126" align="center” bgcolor="#FFFFFF'> 下 一 部 : <a 
href="index.php?page=<?php 
过 ($_GET [page] 一 "or$_GET [page] <=1) {// 判 断 如 果 page 的 值 等 于 空 或 者 小 于 等 于 1 则 输出 2 
echo 2; 
} else if($_ GET [page] >= $page_count) { 
echo $page_count; // 判 断 如 果 page 的 值 超过 总 记录 则 输出 总 记录 数 
}else { 
echo ceil ( ($_GET [page] * 2+ 1) 12); /根据 当前 页 page 的 值 ， 计 算 下 一 页 page 的 值 
} 
"> 
<?php 
$page 4=($_GET [page])* 2; /获取 下 一 页 中 输出 的 第 一 条 记录 的 值 
if($page 4<=0){ 
Spage 4= 2: // 如 果 $page_4 的 值 小 于 等 于 0， 则 输出 2 
h 
if ($page 4 一 $page count * 2) { // 如 果 $page_4 的 值 等 于 总 记录 数 的 2 倍 
Spage 4=$page count* 2 - 1: // 则 输出 总 记录 数 的 2 倍 减 1 的 值 
} 
$query_4 = mysql query ("select * 位 om tb_book limit $page 4,1" );，// 以 变量 page 4 的 值 为 条 件 ， 
执行 查询 语句 
$myrow_4 = mysql fetch array ( $query_4 ); 
echo $myrow_4 [bookname]: // 输 出 指定 的 数据 
2 
</a></td> 


最 后 ， 实 现 以 10 页 为 一 个 单位 ， 实 现 上 10 页 和 下 10 页 的 跳 转 ， 并 且 可 以 在 当前 页 


显示 的 10 个 超 链接 中 任意 跳 转 。 其 关键 代码 如 下 : 


<td width="129" align="center" bgcolor="#FFFFFF"><span class="STYLE2"> 分 页 : 


<2?php 
Snext=$_ GET [link type] * 10; // 定 义 变量 ， 以 10 页 为 一 个 单位 
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Sn = $link type- 1: 1 上 10 页 | 
$m= $link type + 1: // 下 10 页 | 
$prev_ page=$_GET [page] - 10; /当前 页 的 上 10 页 | 
if($_GET [link type] — 0) { /如 果 当 前 页 的 值 为 0， 则 输出 首页 图 标 | 
echo "<img src=\"images/02.jpg\" width=\"8\" height=\"9\" border=\"0\" title=\" 首 页 \">"; | 

} else { // 否 则 ， 输 出 首页 超 链接 ， 并 为 上 10 页 设置 链接 | 


echo "<a href='index.php?vv=0&link type=0&page=1><img src=\"images/02.jpe\" ， 
width=\"8\" border=\"0\" height=\"9\" border=\"0\" title=\" 首 页 "></a>&nbsp;"; 
$ccc=S$vv - 10; // 变 量 $vv 是 当前 10 页 的 起 始 位 置 , $cce 是 上 一 个 10 页 的 起 始 位 置 
echo "<a hre 合 index.php?vv=$ccc&link type=$n&page=$prev_page'><img 
src=\"images/01.jpe\" width=\"8\" height=\"9\" border=\"0\" title=\" 上 十 页 \"></a>":; | 
} 


> | 
<2php 
for($j = 1; $j <= $page_count; $j ++) { /应 用 for 循环 ， 输 出 当前 页 的 10 个 超 链接 
Spnext = $next + $j; // 定 义 当 前 页 输出 的 页 码 值 
这 (mm 一 10){ // 判 断 当 $mm 的 值 等 于 10 时 跳出 循环 
break: 


} 
if ($mm> $page count) { // 判 断 如 果 变 量 mm 的 值 大 于 总 的 记录 数 ， 跳 出 循环 
break: 


} 
让 ($page count-$vv<10){ /如 果 总 的 记录 数 减 去 当前 10 页 的 值 小 于 10 
这 ($mm >= $page_count - $vv) {// 判 断 当 变量 mm 的 值 大 于 总 的 记录 数 减 去 当前 10 页 的 值 时 ， 


跳出 循环 
break: 
} 
} 
?> 
<?php 
echo "<a href='index.php?vv=$vv&link type=$link type&page=$pnext> $pnext </a>"; 
Smm= $mm+ 1; // 变 量 mm 的 值 增加 
} 
?> 
</span></td> 
<td width="28" align="center” bgcolor="# FFFFF"><span class="STYLE2"> 
<2?php 
$VV = $V + $mm; /定义 下 10 页 的 起 始 位 置 
寺 ($page_count - $vv <= 0) {// 判 断 当 总 记录 数 小 于 等 于 下 10 页 的 起 始 位 置 时 ， 输 出 尾 页 | 
图 标 | 


echo "<img src=\"images/03.jpe\" width=\"8\" height<\"9\" border=\"0\" titlea\" 尾 页 >"; | 

} else{ // 否 则 输出 下 10 页 的 超 链接 | 

echo "<a hre 人 index.php?vv=$vv&link type=$m&page=$pnext><img ste=\"images/03. | 

jpg\" width=\"8\" height=\"9\" border=\"0\" title=\" 下 十 页 ></a>"; | 
} | 

if ($message count —0){ // 判 断 当 总 记录 数 等 于 0 时， 输出 没有 记录 | 

echo "没有 记录 !"; | 

} | 

2> | 
</span></td> | 
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可 
| 技术 要 点 
| 上 下 分 页 以 当前 页 码 为 基础 ， 实 现 上 一 页 和 下 一 页 的 跳 转 ， 并 且 输出 上 一 页 的 最 后 一 
国内 “| 条 数据 和 下 一 页 的 第 一 条 数据 的 内 容 。 
= 一 | 在 输出 数据 库 中 的 数据 时 应 用 分 栏 方法 ， 通 过 一 个 1 行 2 列 的 表格 来 输出 数据 库 中 的 
BE 数据。 其 实现 的 原理 是 : 
(1) 在 while 语句 之 外 ， 定 义 一 个 变量 $number=0。 
| (2) 在 while 语句 之 中 ， 通 过 站 语句 判断 取 模 $number % 2) 的 值 是 否 等 于 0， 如 
| 果 等 于 0 则 是 行 的 开始 执行 <x>)。 
| (3) 在 while 语句 之 中 ， 通 过 让 语句 判断 取 模 ($number % 2) 的 值 是 否 等 于 0， 如 
| 果 不 等 于 0 则 是 行 的 结束 (执行 Aw>)。 
(4) 在 while 语句 之 外 ， 执 行 Snumber++。 


实例 108 通过 PHP 面向 对 象 实现 数据 分 页 


| ( 实例 位 置 : 配套 资源 \SL\0G\108 视频 位 置 : 配套 资源 \SP\06\108 ) 


实例 说 明 
实例 107 介绍 的 是 通过 PHP 的 面向 过 程 的 编程 方式 实现 数据 的 分 页 输出 , 本 实例 介绍 
| 通过 面向 对 象 的 编程 方式 实现 数据 的 分 页 输出 。 运 行 结 果 如 图 6.13 所 示 。 


| 
遇 8 二 新 上 染 导 侣 全 入、 实 P 芝 四 可 下滑 万 站 
- a 
VOIP AE 
EE 
三 地 好 , 肥 天 商 呈 和 革 录 pi 
各 所 [ ] 


a EI | a | 


前 格 出 版 时 间 作者 出 版 杜 
了 从 入 「 艺 沪 竹 多 ”| 2000-;0-01 | ” 台 日 和 法 ”人民 闻 虹 版 入 
| 
明日 电子 识 城区 关 开业 了 4 。 共有 图 忆 6 二 己 页 显示 4 志 第 > 页 / 共 页 痛 页 上 一 页 下 一 页 悍 页 


1 4 党 间 和 


图 6.13 分 页 输出 数据 库 中 数据 

| 在 本 实例 中 应 用 面向 对 象 编程 ， 将 分 页 方法 定义 到 一 个 类 文件 中 ， 通 过 对 这 个 类 的 实 
| 例 化 操作 ， 完 成 数据 库 中 数据 的 分 页 输出 。 
| 具体 步 又 如 下 ; 
”0) 创建 page 类 ， 定 义 分 页 方法 和 分 页 超 链接 的 方法 ， 详 细 代 码 可 参考 技术 要 点 中 
| 的 内 容 。 

(2) 实例 化 page 类 , 通过 listmfo0 方 法 和 toPage0 方 法 完成 分 页 输出 数据 库 中 数据 的 
避 .170 ， 
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操作 ， 其 关键 代码 如 下 : 


<?php 
Sobj=new page(4,$_GET["page"]); // 实 例 化 page 类 
S$obj->listmfo0: /执行 分 页 方法 
$obj->toPage0: /执行 分 页 超 链接 的 方法 


?> 


面向 对 象 的 分 页 关键 就 是 分 页 类 的 创建 和 类 的 实例 化 。 这 里 使 用 的 是 分 页 类 page, 在 
该 类 中 通过 listInfo0 方 法 完成 数据 的 分 页 操作 ;通过 toPage0 方 法 完成 数据 分 页 超 链 接 的 
创建 。page 类 的 关键 代码 如 下 : 


<?php 

class page{ 
private $pagesize; // 定 义 成 员 变量 

private $page; // 定 义 成 员 变量 

private $pagecount; // 定 义 成 员 变量 

private $total; // 定 义 成 员 变量 

private $conn; // 定 义 成 员 变量 

public function _ construct($pagesize,$page){ // 定 义 构造 方法 ， 获 取 参 数 传递 的 方法 
S$this->pagesize=$pagesize; 1/ 设置 成 员 变量 的 值 
S$this->page=$page; // 设 置 成 员 变量 的 值 

} 

public function listInfoO) { // 声 明 方 法 
if($this->page—"" | !is_numeric($this->page)) { /如 果 分 页 变量 的 值 为 空 

S$this->page=1; // 则 为 变量 赋值 1 

} 


$this->conn=mysql_connect("localhost","root","111"); // 连 接 数 据 库 服务 器 
mysql select_db("db_database06".$this->conn): // 连 接 数 据 库 

mysql_query("set names gb2312"): // 设 置 编 码 格式 | 
$sql=mysql query("select count(*) as total from tb_book",$this->conn); /执行 查询 | 
$myrow=mysql fetch_array($sq)): | 


S$this->total=$myrow[total]: // 获 取 查 询 结果 
if($this->total=—0){ // 判 断 如 果 查 询 结果 为 0， 则 输出 如 下 内 容 | 
echo "<table width=520 height=20 border=0 align=center cellpadding=0 cellspacing=0>"+ | 
"<tr>"+ | 
"<td><div align=center> 暂 无 图 书信 息 ! </div></td>"+ | 
"</tr>"+ | 
"</table>": | 
Jelse{ // 否 则 | 


这 (Sthis->total % $this->pagesize) 一 0) 贡 判断 如 果 总 的 记录 数 除 以 每 页 显示 的 记录 数 等 于 0 | 
S$this->pagecount=intval($this->total/$this->pagesize); // 则 为 变量 pagecount 赋值 | 


jelsef | 
这 $this->total<=$this->pagesize){ 如 果 查 询 结果 小 于 等 于 每 页 记录 数 ， 那 么 为 变量 赋值 为 1 | 
S$this->pagecount=1; | 
jelsef | 
$this->pagecount=ceil($this->total/$this->pagesize); 。“”// 否 则 输出 变量 值 | 

| 
。171 。 
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$sql=mysql_query("select * from tb book order by id desc limit ".$this->pagesize*($this-> 
page-1).",$this->pagesize",$this->conn); 


?> 
天 六 .…// 省 略 了 部 分 代码 
全 一 <2php 
while($myrow=mysql fetch_ array($sql)){ 
> 
<tr> 
<td height="20" bgcolor="# FFFFF"><div align="center"><?php echo $myrow[bookname]:?> 
</div></td> 
<td height="20" bgcolor="#F FFFFF"><div align="center"><?php echo $myrow[price]:?> 
</div></td> 
<td height="20" bgcolor="#F FFFFF"><div align="center"><?php echo $myrowlissuDate]:?> 
</div></td> 
<td height="20" bgcolor="#FFFFFF"><div align="center"><?php echo $myrow[maker];?> 
</div></td> 
<td height="20" bgcolor="#FFFFFF"><div align="center"><?php echo $myrow[publisher]:?> 
</div></td> 
</tr> 
<2php 
} 
echo "</table>"; 
) 
} 
public function toPageO{ // 声 明 方 法 ， 创 建 分 页 的 超 链 接 
> 


<table width="520" height="24" border="0" align="center" cellpadding="0" cellspacing="0"> 
<tr> 
<td width="342 心 &nbsp: 共 有 图 书 &nbsp:<?php echo $this->total:?>&nbsp: 本 &nbsp: 每 
页 显示 &nbsp;<?php echo $this->pagesize;?>&nbsp: 本 &nbsp: 第 &nbsp:<?php echo S$this->page;?>&nbsp; 页 / 
共 &nbsp;<?php echo $this->pagecount:?>&nbsp; 页 </td> 
<td width="362"><div align="right’> 
<a href="<?php echo $_SERVER["PHP_SELF"]?>?page=1"> 首 页 </a> 
<a href="<?php echo $_SERVER["PHP_SELF"]?>?page=<?php 
if($this->page>1) 
echo $this->page-1; 
else 
echo 1: 
?>"> 上 一 页 </a> 
<a href-"<?php echo $_SERVER["PHP_SELF"]?>2page=<?2php 
1f($this->page<$this->pagecount-1) 
echo $this->pagetl:; 
else 
echo $this->pagecount: 
?>"> 下 一 页 </a> 
<a href="<?php echo $ SERVER["PHP SELF"]?>?page=<?php echo $this-> 
pagecount;?>"> 尾 页 </a> 
</div></td> 


Ss 


: 上 
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public function _ destructO{ // 声 明 方法 关闭 数据 库 
mysql_close($this->conn); 
} 
} 


> | 


实例 109 ”查询 结果 不 显示 重复 记录 | 


( 实例 位 置 : 配套 资源 \SL\06\109 ) 


实例 说 明 | 

在 某 些 管理 系统 中 所 录入 的 数据 包含 重复 记录 是 不 可 避免 的 ， 为 了 在 前 台 显示 时 不 显 | 
示 重 复 的 记录 可 以 通过 SQL 语言 的 关键 字 distinct 实现 。 运 行 本 实例 ， 如 图 6.14 所 示 ， 图 | 
书信 息 中 不 显示 价格 相同 的 信息 。 | 


要 询 结 黑 不 旦 示 重 复 记 录 
书 名 
pHRP 开 发 实战 宝典 
8 开发 实战 宝典 


图 6.14 去 掉 重复 项 输出 
实现 过 程 
创建 脚本 文件 indexphp， 启 动 MySQL 服务 器 ， 连 接 MySQL 数据 库 。 单 击 按钮 显示 | 
信息 。 核 心 代码 如 下 : | 


<2php | 
if($_POST[submit]){ // 单 击 按钮 | 
if($_POST[text] != "|| $_POST[text] (= "输入 图 书 价格 "){ /判断 文本 框 信息 | 
if(preg_match("/[^a-zA-Z_1/",$_POST[text]){ // 正 则 表达 式 验 证 信息 | 

// 返 回 结果 集 | 

S$rs = mysql_query("select distinct * from tb_demo031 where price ='$_POST[text] 元 "); | 

?> ! 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> | 
书 名 </td><td background="pic/head.JPG"> 价 格 </td><td background="pic/head.JPG"> 日 期 <td></tr> | 
<2php | 
while($rst = mysql_fetch row($rs)){ /循环 输出 结果 ! 
?> 

<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"><?php 
echo S$rst[1]:?></td><td background="pic/head.JPG"><?php echo S$rst[2]:?></td><td background="pic/head. 

JPG"><?php echo $rst[3]:?></td></tr> 
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<2php 
} 
| jelse{ 
| echo "<script>alert( 输 入 不 是 一 个 数值 ));</script>"。 ”//JavaScript 提示 
a } 
全 网 | Jelse{ 
echo "<script>alert( 请 输入 信息 ');</script>"; //JavaScript 提示 
| } 
| } 
| > 
| 技术 要 点 
SQL 语句 中 实现 查询 结果 中 不 显示 重复 记录 可 以 通过 关键 字 distinct 实现 ， 该 关键 字 
| 使 用 的 格式 如 下 : 


select distinct 字段 名 from 表 名 where 查询 条 件 


| distinct 关键 字 可 以 在 查询 结果 中 去 除 重复 行 ， 与 其 对 应 的 还 有 关键 字 al， 在 SQL 语 
| 名 中 加 入 关键 字 all， 表 示 显 示 所 有 的 记录 。 如 果 SQL 语句 中 这 两 个 关键 字 都 不 加 则 查询 
| 结果 中 将 显示 所 有 的 记录 。 


实例 110 Delete 语句 删除 图 书信 息 


( 实例 位 置 : 配套 资源 \SL\06\110 ) 


实例 说 明 

数据 库 可 以 长 期 储存 数据 ， 但 是 对 于 一 些 已 经 过 期 不 再 使 用 的 数据 或 者 元 余数 据 信 
| 息 ， 如 果 不 及 时 删除 ， 会 影响 到 MySQL 服务 器 的 运行 效率 。 所 以 删除 不 再 使 用 的 数据 是 
| 十 分 必要 的 。 本 实例 通过 Delete 语句 实现 删除 图 书信 息 ， 运 行 结 果 如 图 6.15 所 示 。 


人 SID 
TD 书 名 价格 日 期 
1 PAP 开 发 实战 字典 80 元 2010-07-17 
2 VB 开发 实战 宝 幅 80 元 2010-07-17 
3 JAYA 开 发 实战 宇 峰 79 元 2010-07-17 
4 JAYAWEB 开 发 实战 宝 要 718 元 2010-07-17 


图 6.15 删除 图 书信 息 


| 
| 守 


| 实现 过 程 
具体 步骤 如 下 : 
(1) 创建 in.php 文件 ， 通 过 面向 对 象 的 知识 编写 数据 库 连 接 类 。 
| (2) 创建 index.php 文件 。 首 先 ， 创 建 form 表单 ， 将 删除 数据 的 ID 提交 到 本 页 。 然 
| 后, 包含 数据 库 连接 类 并 实例 化 对 象 ， 判断 表单 中 提交 数据 是 否 符合 要 求 , 如 果 符合 要 求 ， 
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则 执行 Delete 语句 。 最 后 ， 循 环 输出 数据 表 中 信息 ， 核 心 代码 如 下 : 


<?php 
include("in.php"); // 包 含 数 据 库 连接 类 
new mysql("localhost","root","l11","db_database06"); // 实 例 化 对 象 
if($_POST[sub]) { / 单 击 “ 删 除 ”按钮 
if(preg_match("N\d/",$ POST[na]){ // 首 先 验证 文本 框 是 否 为 数字 ， 
if(mysql_query("delete from tb_demo029 where id-'$ POST[na]")){// 执 行 删 除 操 作 
echo "<script>alert( 删 除 成 功 ");</script>"; // 输 出 提示 | 
}else{ | 
echo "<script>alert(' 您 输入 的 商品 ID 不 在 范围 内 ");</script>"; | 
}; | 
}else{ | 
echo "<script>alert(' 您 输入 的 图 书 ID 不 是 数字 ');</script>"; | 
} | 
} | 
S$rs = Imysql_ query("select * from tb_demo029"); // 查 询 操作 输出 信息 | 


echo "<table width='580px'><td>ID</td><td> 书 名 </td><td> 价 格 </td><td> 日 期 <td></tr>"; 
while($rst = mysql fetch row($rs)){ 
echo "<td>".$rst[0]."</td><td bgcolor=#FFFFFF'>".$rst[1]."</td><td>".$rst[2]."</td><td 
bgcolor=#FFFFFF'>".$rst[3]."</td></tr>"; 


} 
echo "</table>"; 
> 


技术 要 点 
Delete 语句 删除 表 中 的 数据 通常 有 两 种 形式 : 一 是 可 以 一 次 从 表 中 删除 多 条 数据 ， 二 
是 只 删除 一 条 记录 。 其 语法 格式 如 下 : 


DELETE [FROM] 
{table_name | view_name} | 
[WHERE search_conditions] | 


参数 说 明 : 

回 table name: 指定 要 删除 数据 的 数据 表 的 名 称 。 

回 “view_name: 用 于 要 删除 数据 的 视图 。 

回 ”search_conditions: 使 用 搜索 条 件 来 限定 要 删除 的 数据 行 。 


实例 111 对 统计 结果 进行 排序 


( 实例 位 置 : 配套 资源 \SL\06\111 ) | 


实例 说 明 


在 商品 信息 管理 系统 中 ， 经 常 需要 对 商品 的 价格 、 数 量 进行 求 和 ， 然 后 根据 所 求 得 的 
值 对 商品 进行 排序 ， 从 而 实现 商品 的 排序 输出 。 运 行 本 实例 ， 如 图 6.16 所 示 ， 将 单一 类 型 
商品 求 和 并 按 商 品 数量 和 商品 单价 排序 。 
ws 


12010-07-21 14000 元 
010-07-21 9500 元 


[2010-07-21 25000 元 
EU 35000 元 
2010-07-21 4000 元 
01 0-07-21 5000 元 


图 6.16 对 统计 结果 进行 排序 
现 过 程 
创建 脚本 文件 index.php， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “ 排 序 ” 
按钮 时 显示 运行 结果 内 容 如 图 6.16 所 示 。 
<2php 

$conn = mysql_connect("localhost","root","111") or die("connect mysql false"); /连接 MySQL 
mysql_select_db("db_database06",$conn) or die ("connect database false"):// 连 接 MySQL 数据 库 
mysql_query("set names utf8"); /设置 编码 格式 


这 $_POST[sub]){ // 单 击 按钮 
$rs = mysql_ query("select * from tb_demo054 order by mount desc,price asc"); /返回 结果 集 


?> 
<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 
商品 </td><td background="pic/head.JPG"> 数 量 </td><td background="pic/head.JPG"> 价 格 </td><td background= 
"pic/head.JPG"> 日 期 </td><td background="pic/head.JPG"> 总 价值 </td></tr> 
<2php 
while($rst = mysql_fetch row($rs){ /循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head.JPG"> 
<?php echo $rst[1]:?></td><td background="pic/head.JPG"><?php echo S$rst[2]:?> 件 </td><td background="pic/ 
head.JPG"><?php echo $rst[3]:2> 元 </td><td background="pic/head.JPG"><?php echo S$rst[4]:?><td background= 
"pic/head.JPG"><?php echo S$rst[2]*$rst[3]:?> 元 </td></td></tr> 
<2php 


技术 要 点 
SQL 语言 中 实现 对 某 字 段 所 有 数据 求 和 可 以 通过 函数 sum0 实 现 ， 该 函数 的 使 用 格式 
如 下 : 
sum([a 册 字段 名 ) 或 sum([distinct] 字 段 名 ) 
sum 中 的 参数 如 果 为 all 加 字段 名 则 表示 对 该 字段 中 的 所 有 记录 进行 求 和 ， 包 括 重 复 
记录 ; 如 果 sum 中 的 参数 为 distinct 加 字段 名 则 表示 对 该 字段 的 所 有 不 重复 记录 进行 求 和 ， 
在 select 语句 中 使 用 sum0) 函 数 的 格式 如 下 : 
select sum( 字 段 名 ) as 新 字段 名 fom 表 名 where 查询 条 件 
*。176。 
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本 实例 实现 对 统计 结果 排序 的 SQL 语句 代码 如 下 : 
select * from tb_demo054 order by mount desc,price asc; 


实例 112 使 用 select 子 句 进行 多 表 查 询 


( 实例 位 置 配套 资源 \SL\06\112 视频 位 置 配套 资源 \SP\06\112 ) 


实例 说 明 | 


在 实际 项 目 开 发 过 程 中 ， 经 常 需 要 将 不 同 的 信息 存储 在 不 同 的 表 中 ， 表 与 表 之 间 通 过 | 
某 字段 相互 关联 , 从 而 使 表 的 指针 形成 一 种 连 动 关系 进而 可 以 通过 SQL 语言 的 select 语句 | 
实现 多 表 查 询 。 运行 本 实例 , 如 图 6.17 所 示 , 在 图 中 文本 框 中 输入 要 查询 成 绩 的 学 生 学 号 ，| 
单 击 “ 查 询 ” 按 钮 即 可 将 学 生 信息 和 该 学 生 的 各 科 成 绩 查找 出 来 。 


-和 torm 子 日 进 行 多 表 查 词曲 


学 生 10 学 生 姓名 ”家庭 住址 入 学 日 期 。 数学 考试 分 数 英语 考试 分 数 。 语文 考试 分 数 
1 小 杨 吉林 长 春 2010-07-22 92 80 99 


图 6.17 多 表 查 询 
实现 过 程 


创建 index.php 文件 ， 当 用 户 在 文本 框 中 输入 数据 并 单 击 “ 查 询 ” 按 钮 时 显示 如 图 6.17 | 
所 示 的 内 容 。 核 心 代码 如 下 : | 


<?php 
$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL false");// 连 接 MySQL 
mysql select_db("db_database06",$conn): /连接 数据 库 | 
mysql query("SETNAMES UTF8"): /设置 编码 格式 
这 $_POST[sub]){ // 单 击 按钮 


/返回 结果 集 | 

S$rs = mysql query("select a.id,a.name,a.address,a.date,b.math,b.english,b.chinese from tb_ | 

demo065 _ tel as b,tb_demo065 as a where a.id=b.id and a.id='$_POST[text]"); | 

> ! 

<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head. | 

JPG"> 学 生 姓 名 </td><td background="pic/head.JPG"> 家 庭 住 址 </td><td background="pic/head.JPG"> 入 学 日 | 

期 </td><td background="pic/head.JPG"> 数 学 考试 分 数 </td><td background="pic/head.JPG"> 英 语 考试 分 数 | 

</td><td background="pic/head.JPG"> 语 文 考试 分 数 </td></tr> | 

<2php | 

while($rst = mysql fetch row($rs)){ /循环 输出 结果 | 

> | 

<tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head.JPG"> 

<?php echo S$rst[1];?></td><td background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/ 

head.JPG"><?php echo $rst[3]:?></td><td background="pic/head.JPG"><?php echo S$rst[4]:?></td><td background= 
"pic/head.JPG"><?php echo $rst[5]:?></td><td background="pic/head.JPG"><?php echo $rst[6]:?></td></tr> 


i 
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| > 
| 技术 要 点 
| SQL 语言 中 通过 where 子 句 实现 多 表 查 询 ， 所 要 查找 的 字段 名 最 好 用 “ 表 名 .字段 名 ” 
| 表示 ， 这 样 可 以 防止 因 表 之 间 字 段 重 名 而 造成 无 法 获知 该 字段 属于 哪个 表 ， 在 where 子 句 
| 中 多 个 表 之 间 所 形成 的 连 动 关 系 应 按 如 下 形式 书写 : 
| 表 1 字段 = 表 2. 字 段 and 其 他 查询 条 件 
综 上 所 述 ， 实 现 多 表 查 询 ， 应 按 如 下 形式 : 

select 字段 名 from 表 工 表 2.. where 表 1 字段 = 表 2. 字 段 and 其 他 查询 条 件 


实例 113 合并 多 个 结果 集 


( 实例 位 置 : 配套 资源 \SL\06\113 ) 


例 说 明 
SQL 语言 中 使 用 关键 字 union 可 以 将 多 张 表 的 信息 合并 输出 。 图 6.18 为 数据 库 中 无 关 
联 的 两 张 信 息 表 ， 运 行 本 实例 ， 单 击 “ 合 并 ”按钮 即 可 将 这 两 张 表 的 信息 合并 输出 ， 如 
图 6.19 所 示 。 


id nome price dote i nome pwd 

a 15100 20100724 用 XX 1 4 声 t081 

le sl 5000 20100724 三 XK 2 i108 

Fr HX 3 Ba 机 3500 20100724 FF 2 X 3 4 刘 1015 

FX 4 Mts 1200 Mm F077 
图 


| 图 6.19 合并 多 个 结果 集 
”实现 过 程 
| 创建 脚本 文件 index.php， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “合并 ” 
| 按钮 时 显示 如 图 6.19 所 示 的 内 容 。 代 码 如 下 : 


<?php 
$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL false"):// 连 接 MySQL 
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mysql select db("db_database06",$conn): // 连 接 数 据 库 
mysql query("SET NAMES UTF8"); // 设 置 编码 集 
if($_ GET[id] =—= "1"){ // 当 i 等 于 1 时 
// 返 回 结果 集 | 
S$rs=mysql_query("'select uid ,name.price fiom 也 demo067 tel union selectidnamepwd from 也 demo067") or die | 贪 站 
("false"); | 窒 一 
x 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> | 

名 称 </td><td background="pic/head.JPG"> 说 明 </td></tr> | 
<?php 

while($rst = mysql fetch array($rs)){ /循环 输出 

?> | 

<tr><td background="pic/head.JPG"><?php echo S$rst[0];?></td><td background="pic/head.JPG"> | 

<?php echo $rst[1];?></td><td background="pic/head.JPG"><?php echo $rst[2]:?></td></tr> | 
<2php 


SQL 语言 中 可 以 通过 关键 字 union 或 al 将 多 个 select 语句 的 查询 结果 合并 输出 , 这 两 | 
个 关键 字 的 使 用 说 明 如 下 : | 
(1) union 利用 该 关键 字 可 以 将 多 个 select 语句 的 查询 结果 合并 输出 ， 并 删除 重复 行 。 | 
(2) all: 利用 该 关键 字 也 是 将 多 个 select 语句 的 查询 结果 合并 输出 但 不 删除 重复 行 。 | 
在 使 用 union 或 al 关键 字 将 多 张 表 合并 输出 时 , 查询 结果 必须 具有 相同 的 结构 并 且 数 | 
据 类 型 必须 兼容 。 | 


实例 114 简单 的 嵌 套 查询 


( 实例 位 置 : 配套 资源 \SL\06\114 ) 


实例 说 明 | 
在 数据 库 系 统 开发 过 程 中 嵌 套 查询 被 广泛 地 应 用 ， 本 实例 将 通过 嵌 套 查询 实现 按 指 
定 的 学 生 学 号 查询 学 生 的 成 绩 信息 。 运 行 本 实例 ,如 图 6.20 所 示 ， 首 先 在 图 中 的 文本 框 中 | 
输入 要 查询 的 学 生 的 学 号 ， 然 后 单 击 “查询 ”按钮 即 可 将 该 学 号 所 对 应 的 学 生 信 息 查 找 | 
出 来 。 | 


1 小 杨 男 2010-07-24 


图 6.20 顽 套 查询 | 
as 人 79s UD 
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> 
实现 过 程 

创建 脚本 文件 index.jphp， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 ， 在 文本 框 中 输入 
学 生 ID， 单 击 “ 查 询 ” 按 钮 ， 显 示 如 图 6.20 所 示 内 容 。 核 心 代码 如 下 : 


<2php 
$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL false");// 连 接 MySQL 
mysql select_db("db_database06",$conn); /| 连接 MySQL 数据 库 
mysql query("SET NAMES UTF8"); // 设 置 编码 格式 
这 $_POST[sub]){ // 单 击 按钮 
// 返 回 结果 集 


$rs = mysql query("select id,name,sex,date from tb demo068 where id in(select id from 
tb_demo068 where id=$ POST[text])") or die ("false"); 
> 
<table width="580px"><tr><td background="pic/head.JPG"> 学 生 ID</td><td background="pic/head. 
JPG"> 学 生 姓名 </td><td background="pic/head.JPG"> 学 生性 别 </td><td background="pic/head.JPG"> 入 学 时 


| 间 </td></t> 


<?php 
while($rst = mysql_fetch_array($rs)){ /循环 输出 结果 
?> 
<tr><td background="pic/head.JPG"><?php echo S$rst[0];?></td><td background="pic/head.JPG"> 


| <?php echo $rst[1];?></td><td background="pic/head.JPG"><?php echo $rst[2]:?></td><td background="pic/ 
| head.JPG"><?php echo S$rst[3]:?></td></tr> 


| 技术 要 点 


<2php 
} 
} 


2 


本 实例 是 通过 一 个 檬 套子 查询 实现 的 。 子 查询 是 一 个 select 查询 ， 返 回 单个 值 且 嵌 套 
在 select、insert、update 和 delete 语句 或 其 他 查询 语句 中 。 任 何 可 以 使 用 表达 式 的 地 方 都 
可 以 使 用 子 查询 。 
子 查询 也 称 内 部 查询 或 内 部 连接 ， 包 含 子 查询 的 语句 称 为 外 部 查询 或 外 部 选择 。 本 实 
例 中 实现 嵌 套 查询 的 代码 如 下 : 
select id,name,sex,date firom tb demo068 where id in(select id from tb demo068 where id=$_ 
POST[text]); 


实例 115 用 ih 查询 表 中 的 记录 信息 


( 实例 位 置 : 配套 资源 \SL\06\115 ) 


实例 说 明 
SQL 语言 中 可 以 利用 关键 字 in 来 查询 表 中 满足 一 定 条 件 的 记录 ， 运 行 本 实例 ， 如 
图 6.21 所 示 ， 首 先 在 图 中 文本 框 中 输入 要 查询 的 图 书 名 称 ， 单 击 “ 查 询 ” 按 钮 即 可 将 与 用 
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户 输入 的 查询 关键 字 相 匹配 的 图 书 查找 出 来 。 


ET GO 


ER [= 


图 书 编号 图 书 名 称 EL 困 书 作者 
下 


《4SP. NET 编 程 宝 央 》 机 械 工业 出 版 社 明日 科技 
《PAP 范例 实战 宝 实 》 清华 大 学 出 版 社 明日 科技 


图 6.21 用 in 查询 表 中 记录 
现 过 程 
创建 脚本 文件 index.php。 编 写 网 页 框架 ， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 
编写 <form> 表 单 ， 当 单 击 “ 查 询 ” 按 钮 时 显示 如 图 6.21 所 示 的 内 容 。 核 心 代码 如 下 : 


<2?php 
这 $_POST[sub]){ // 单 击 “ 查 询 ” 按 钮 
这 $_ POST[te] 一 "" || $_ POST[te] 一 "输入 关键 字 "){ // 对 文本 框 信息 进行 判断 
echo "<script>alert( 请 输入 内 容 ");</script>"; //JavaScript 提示 
}else{ 
//sql 语句 


$sql = "select * from tb_demo084 where name in (select name from tb_demo084 
Where name like '%$_ POST[te]%o' ) "; 
Srs = mysql_query($sql): // 返 回 结 果 集 
ea 
<table width="580px"><tr><td background="pic/head.JPG" align="center"> 图 书 
编号 </td><td background="pic/head.JPG" align="center> 图书 名 称 </td><td background="pic/head.JPG" 
align="center"> 出 版 社 </td><td background="pic/head.JPG" align="center"> 图 书 作者 </td></tr> 
<?php 
while($rst = mysql fetch row($rs)){ // 循 环 输出 结果 
?> 
<tr><td background="pic/head.JPG" align="center"><?php echo $rst[0]:?></td> 
<td background="pic/head.JPG" align="center"><?php echo $rst[1]:?></td><td background="pic/head.JPG" 
align="center"><?php echo $rst[2]:?></td><td background="pic/head.JPG" align="center"><?php echo S$rst[3];?> 
</td></tr> 
<2php 


本 实例 首先 通过 in 子 查 询 查找 出 所 有 与 用 户 输入 的 关键 字 相 匹配 的 图 书 名 称 , 然后 通 
过 外 部 查询 查找 出 所 有 图 书 的 详细 信息 ， 代 码 如 下 : 


select * from tb _demo084 where name in (select name from tb demo084 where name like '%$_ 
POST[te]%'; 


“8s 
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多 
实例 116 使 用 聚集 函数 sum() 对 学 生成 绩 进 行 汇总 


( 实例 位 置 : 配套 资源 \SL\06\116 ) 


实例 说 明 


在 学 生成 绩 管理 系统 中 ， 经 常 需要 求 出 班级 所 有 学 生 的 各 科 成 绩 总 和 ， 从 而 求 出 所 有 
学 生 的 各 科 平 均 成 绩 。 运 行 本 实例 ， 如 图 6.22 所 示 ， 单 击 图 中 的 “对 学 生成 绩 汇 总 ”按钮 
| 即 可 将 班级 的 各 科学 生成 绩 统计 出 来 。 


| 图 6.22 对 学 生成 绩 汇总 

| 实现 过 程 

| 编写 脚本 文件 indexphp， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 ， 当 单 击 “ 对 学 生 
| 成 绩 汇总 ”按钮 时 ， 显 示 如 图 6.22 所 示 信息 。 核 心 代码 如 下 : 

| <?php 


$conn = mysql_connect("localhost","root","111") or die ("connect mysql false"); /连接 MySQL 
mysql select_db("db_database06",$conn) or die ("connect database false");// 连 接 MySQL 数据 库 


| mysql_query("set names utf8"); /设置 编码 格式 
| if($_GET[page] 一 "19{ /page 等 于 1 时 
| S$rss = mysql query("select *,sum(chinese+math+english) as a from tb demo059 group by name 
| order by a desc "); // 返 回 结果 集 
?> 


| <table width="580px"><tr><td background="pic/head. JPG">ID</td><td background="pic/head.JPG"> 
| 学 生 姓名 </td><td background="pic/head.JPG"> 语 文成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 
| </td><td background="pic/head.JPG"> 英 语 成 绩 </td><td background="pic/head.JPG"> 总 成 绩 </td></tr> 
| <?php 
| while($rst = mysql fetch row($rss)){ 1/ 循环 输出 结果 
| 2 
| <tr><td background="pic/head.JPG"><?php echo S$rst[0]:?></td><td background="pic/head. 
| JPG"><?php echo $rst[1];?></td><td background="pic/head.JPG"><?php echo $rst[2];?></td><td background= 
| "pic/head.JPG"><?php echo S$rst[3]:?></td><td background="pic/head.JPG"><?php echo S$rst[4]:?></td><td 
| background="pic/head.JPG"><?php echo $rst[5]?></td></tr> 
| <?php 

} 
} 


Ss 
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技术 要 点 
SQL 语句 中 ， 实 现 对 某 字 段 的 所 有 记录 进行 求 和 可 以 通过 函数 sum0 实 现 ， 二 的 | 
使 用 方法 如 下 : | 
sum([all | distinct] expression) 
参数 说 明 : 
all: 表示 对 指定 字段 的 所 有 值 进行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 不 加 参数 | 
all 或 distinct 则 表示 对 指定 字段 的 所 有 记录 进行 聚集 运算 。 | 
回 distinct: 表示 对 指定 字段 的 所 有 非 重复 记录 进行 求 和 。 
回 “expression: 是 精确 数字 或 近似 数字 数据 类 型 分 类 (bit 数据 类 型 除外 ) 的 表达 式 。 
sum() 函 数 的 返回 类 型 如 表 6.3 所 示 。 


表 6.3 sum() 函 数 的 返回 类 型 


表达 式 结果 返回 类 型 
整数 分 类 int 
decimal 分 类 decimal(38,s) 除 以 decimal(10,0) 
money 和 smallmoney 分 类 mone. 
float 和 real 分 类 float 


实例 117 使 用 聚集 函数 avg 求学 生 的 平均 成 绩 


( 实例 位 置 : 配套 资源 \SL\06\117 ) 


实例 说 明 | 
获取 统计 数据 平均 值 的 方法 有 多 种 ， 例 如 ， 可 以 先 求 得 所 有 数据 的 总 和 ， 然 后 再 除 以 | 
总 个 数 ， 而 SQL 语言 中 提供 了 专门 求 平均 数 的 函数 avg0， 本 实例 将 利用 该 函数 求 得 学 生 | 
成 绩 表 中 各 科学 生成 绩 的 平均 值 。 运 行 本 实例 ， 如 图 6.23 所 示 ， 单 击 图 中 “对 学 生成 绩 | 
站 ”的 按钮 即 可 将 各 科 的 平均 成 绩 显示 出 来 。 


数学 成 绩 
站 

好 

20 

60 

85. 2500 


图 6.23 取得 学 生 的 各 科 平 均 成 绩 


创建 脚本 文件 indexphp。 当 单 击 “ 对 学 生成 绩 汇 总 ”按钮 时 显示 如 图 6.23 所 示 的 内 | 
。183 。 网 
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! Ns 

| te 

Ch、 

| 容 ， 实 现 此 功能 的 核心 代码 如 下 : 

| <2php 

| $conn = mysql_connect("localhost","root","111") or die ("connect mysql false"): /连接 MySQL 
会 和 | Imysql select _ db("db_database06".$conn) or die ("connect database false");// 连 接 MySQL 数据 库 
A | mysql query("set names utf8"); // 设 置 编码 集 

ex 


! <table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 
| 学 生 姓 名 </td><td background="pic/head.JPG"> 语 文成 绩 </td><td background="pic/head.JPG"> 数 学 成 绩 
;</td><td background="pic/head.JPG"> 英 语 成 绩 </td></tr> 

| <2php 

| while($rst = mysql fetch row($rss)){ 1/ 循环 输出 结果 

| 9> 


| if($ GET[page] — "1"){ // 如 果 page 等 于 1 
Srss = mysql_query("select * from tb_demo059"); // 返 回 结果 和 集 


| <tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/ 
| head.JPG"><?php echo S$rst[1]:?></td><td background="pic/head.JPG"><?php echo $rst[2];?></td><td background= 
| "Pic/head JPG"><?php echo Srst[3]:?></td><td background="pic/head JPG"><?php echo Srst[4]:2></td></tr> 

| <2php 


} 
Srts = mysql_query("select avg(chinese),avg(math),avg(english) from tb_demo059");// 返 回 结 


| 果 集 
| S$rsth = mysql_fetch_row($rts); 
> 
| <tr><td background="pic/head.JPG"> 各 科 平 均 成 绩 </td><td background="pic/head.JPG"></td><td 
| background="pic/head.JPG"><?php echo S$rsth[0]:?></td><td background="pic/head.JPG"><?php echo Srsth[1]:?> 
| </td><td background="pic/head.JPG"><?php echo $rsth[1];?></td></tr> 
| <2php 

} 


| 

| 技术 要 点 

获取 某 字 段 的 所 有 记录 的 平均 成 绩 可 以 通过 函数 avg0 实 现 ， 该 函数 的 使 用 方法 如 下 : 
| avg([all | distinct] expression) 

| 木 实例 实现 利用 avg 函数 实现 显示 平均 成 绩 的 SQL 语句 代 码 如 下 

select avg(chinese),avg(math),avg(english) from tb_demo059; 


实例 118 使 用 聚集 函数 min() 求 利润 最 少 的 商品 
( 实例 位 置 : 配套 资源 \SL\06\118 ) 
实例 说 明 


| 在 销售 管理 系统 中 ， 商 家 会 根据 不 同 商品 的 销售 利润 来 确定 该 商品 的 进货 数量 。 运 行 
| 本 实例 ， 如 图 6.24 所 示 ， 单 击 图 中 的 “获取 利润 最 小 的 商品 信息 ”按钮 即 可 将 销售 利润 最 
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小 的 商品 信息 显示 在 图 中 最 后 一 行 。 


合用 聚 货 园 数 MIN 求 利润 最 少 的 高 品 
| 


获取 利润 旭 小 的 商品 信息 


进货 价格 /无 。 请 售 价格 /无 。 进货 数 重 / 件 。 进货 日 其 
1500 1600 加 2010-07-22 
00 3300 2010-07-27 
4500 4500 2010-07-22 
3000 3500 2010-07-22 
100 


图 6.24 利润 最 小 的 商品 输出 
实现 过 程 
创建 脚本 文件 index.php， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “ 获 取 利 
润 最 小 的 商品 信息 ”按钮 时 显示 如 图 6.24 所 示 的 内 容 。 核 心 代码 如 下 : 
<?php 


$conn = mysql_connect("localhost","root","111") or die ("connect mysql false"); /连接 MySQL 
mysql select db("db_database06",$conn) or die ("connect database false");// 连 接 MySQL 数据 库 


mysql_query("set names utf8"); /设置 编码 格式 
S$rss = mysql query("select * from tb_demo061"); // 返 回 结果 集 
?> 


<table width="580px"><tr><td background="pic/head.JPG">ID</td><td background="pic/head.JPG"> 
商品 名 称 </td><td background="pic/head.JPG"> 进 货 价 格 /元 </td><td background="pic/head.JPG"> 销 售 价格 / 
元 </td><td background="pic/head.JPG"> 进 货 数 量 / 件 </td><td background="pic/head.JPG"> 进 货 日 期 
</td></tr> 
<?php 
while($rst = mysql fetch row($rss)){ /循环 输出 结果 
> 
<tr><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/ 
head.JPG"><?php echo $rst[1]:?></td><td background="pic/head.JPG"><?php echo S$rst[2]:?></td><td background= 
"pic/head.JPG"><?php echo S$rst[3];?></td><td background="pic/head.JPG"><?php echo S$rst[4]:?></td><td 
background="pic/head.JPG"><?php echo $rst[5]:?></td></tr> 
<?php 


} 
if($_GET[page] — "1"){ // 当 page 等 于 1 时 
$sql = "select min(outshop-inshop), name from tb_demo061 group by date "; 
/sql 语句 
Srs = mysql_query($sql); // 返 回 结果 集 
Srst = mysql_fetch row($rs); // 输 出 结果 
?> 
<tr><td background="pic/head.JPG"> 利 润 最 小 的 商品 </td><td background="pic/head.JPG"><?php 
echo $rst[1]:?></td><td background="pic/head.JPG"><?php echo $rst[0]:?></td><td background="pic/head. 
JPG"></td><td background="pic/head.JPG"></td><td background="pic/head.JPG"></td></tr></table></td></tr> 
</table></td></tr></table> 
<2php 
} 


> 
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SQL 语言 中 获取 某 字 段 的 最 小 值 可 以 通过 函数 min0 实 现 ， 该 函数 的 使 用 方法 如 下 : 


| mixed min ( number argl, number arg2 , number ...) 
| mixed min ( array numbers , array ...) 


| 数 、 字 符 串 或 浮 点 数 ， 则 至 少 需要 两 个 参数 而 min0 函 数 会 返回 这 些 值 中 最 小 的 一 个 。 可 
| 以 比较 无 限 多 个 值 。 


实例 119 使 用 聚集 函数 max() 求 销售 利润 最 高 的 商品 


( 实例 位 置 : 配套 资源 \SL\06\119 ) 


加 末 仅 有 一 个 参数 日 为 数组 ,min0 隐 数 返回 该 数组 中 最 小 的 值 . 如 果 第 一 个 参数 是 束 


| 商品 销售 管理 系统 中 ， 商 品 的 销售 [骂人 各 MAX IE 站 
| 利润 统计 模块 是 必 不 可 少 的 。 运 行 本 实 一 = | 

| 例 ， 如 图 6.25 所 示 ， 在 图 中 文本 框 中 输 2 

| 入 某 月 份 , 单 击 “ 查 询 ” 按 钮 即 可 将 销售 1 0 

| 领 最 大 商品 信息 显示 出 来。 | 
现 ; 寸 程 357 。 18) 地 石 受 鱼 。。 3000 素 # 广 场 2010-12.07 入 


图 6.25 获取 月 利润 最 大 的 商品 信息 
具体 步骤 如 下 : 
(1) 创建 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 


| <2php 


| $conn=mysql_connect("localhost","root","111"):; // 连 接 MySQL 数据 库 
| mysql_select_db("db_database06",$conn): // 连 接 数 据 库 
mysql query("set names gb2312"): /设置 编码 格式 
?> 
| (2) 显示 商品 表 中 所 有 商品 的 销售 信息 ， 代 码 如 下 : 
| <2php 
| include_once("conn .php"); // 包 含 数据 库 连 接 文 件 
| $sql=mysql_query("select * from tb_demo062",$conn); /执行 查询 操作 
| $info=mysql fetch array($sql): // 返 回 结果 集 
| if($info—false) { // 判 断 结果 集 是 否 存在 
| echo " 暂 无 商品 信息 "; 
| }else{ 
| do{ 
| ?> 
| <t> 
| <td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[id]:?></div> 
| <td> 
| <td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[name]:?> 
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</div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo S$info[sale]:?> 
</div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[shopname]:?> 
</div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[xdate];?> 
</div></td> 
<td height="25" bgcolor="#EFFFFF"><div align="center"><?php echo $info[sellman];?> 
</div></td> 
</tr> 
<2php 
}while($info=mysql fetch array($sql)); // 循 环 输出 结果 
} 
(3) 显示 月 销售 额 最 大 商品 信息 ， 代 码 如 下 : 
<2php 
if($_POST[submit]!=") { // 通 过 POST 方式 传递 参数 
S$yue=$_POST[yue]; // 将 参数 值 赋 给 变量 
$sql=mysql query("select * from tb demo062 where sale in (select max(sale) from 
tb_demo062 where month(xdate)=$yue and year(xdate)=2005)",$conn); // 执 行 查询 操作 
S$info=mysql fetch array($sq]); // 返 回 结果 集 
if($info—false){ // 如 果 结 果 集 不 存在 
echo "不 存在 该 月 !"; 
}else{ 
> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[id]:?></div> 
</td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[name];?> 
</div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo Sinfo[sale]:;?> 
</div></td> 
<td height="25" bgcolor="#EFFFFF"><div align="center"><?php echo $info[shopname]:?> 
</div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[xdate];?> 
</div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo $info[sellman]:?> 
</div></td> 
</tr> 
<?php 
} 
b 
mysql close($conn): // 关 闭 数据 库 连接 
> 
技术 要 点 


实现 本 实例 主要 应 用 到 SQL 语言 中 的 max0 函 数 ， 该 函数 的 语法 格式 如 下 : 
max([all | distinct] expression) 
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可 

参数 说 明 : 

all: 表示 对 指定 字段 的 所 有 值 进 行 聚集 函数 运算 ，all 为 默认 值 ， 如 果 不 加 参数 
all 或 distinct 则 表示 对 指定 字段 的 所 有 记录 进行 聚集 运算 。 

distinct: 表示 对 指定 字段 的 所 有 非 重复 记录 进行 求 最 大 值 。 

expression: 是 精确 数字 或 近似 数字 数据 类 型 分 类 (bit 数据 类 型 除外 ) 的 表达 式 。 


实例 120 使 用 聚集 函数 count0 求 利润 大 于 某 值 的 数据 


( 实例 位 置 : 配套 资源 \SL\06\120 ) 


| 实例 说 明 
| 在 PHP 项 目 开 发 过 程 中 ，SQL 语言 的 count0 函 数 被 广泛 地 应 用 ， 例 如 ， 在 实现 记录 
| 的 分 页 显示 时 ， 需 要 通过 count0 函 数 求 出 表 中 所 有 记录 总 和 ， 本 实例 将 讲解 SQL 语言 

| count() 函 数 的 应 用 。 运 行 本 实例 ， 如 图 6.26 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 某 数值 ， 然 
| 后 单 击 “ 查 询 ” 按 钮 即 可 将 所 有 利润 大 于 该 数值 的 数据 求 出 。 


0-07-22 


2010-07-22 
2010-07-23 


| 图 6.26 取得 大 于 某 值 的 数据 
| 实现 过 程 


| 创建 脚本 文件 index.php， 启 动 MySQL 服务 并 连接 MySQL 数据 库 ， 当 在 文本 框 中 输 
| 入 内 容 时 ， 单 击 “ 查 询 ” 按 钮 ， 实 现 如 图 6.26 所 示 的 内 容 。 核 心 代码 如 下 : 


| <2php 
| 这 $_POST[sub]){ // 单 击 按钮 
| if($_POST[text] := "上 | $_POST[text] != "输入 查询 值 "){ ””// 判 断 文 本 框 信息 
if(preg_match("N\d/".$_POST[text]){ // 正 则 表达 式 验 证 信息 
| S$rs = mysql_query("select count(*) as a firom tb demo061 where $ POST[text] < outshop");// 返 回 
| 结果 集 
| S$rst = mysql fetch row($rs): // 输 出 结果 
pe 
<table><tr><td width="580px" align="center"> 共 查找 到 <?php echo $rst[0]:?> 条 </td></tr></table> 
<2?php 
jelse{ 
echo "<script>alert( 请 正确 输入 ");</script>"; //JavaScript 提示 
jelse{ 
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统计 表 中 满足 一 定 条 件 的 记录 个 数 ， 可 以 通过 SQL 语言 的 count0 函 数 实现 ， 该 函数 
的 使 用 格式 如 下 : | 
int count ( mixed array [, int mode]) 
count(0) 函 数 的 参数 说 明 如 表 6.4 所 示 。 


表 6.4 count() 函 数 的 参数 说 明 


参数 说 明 
arra 必 选 要 参数 。 输 入 的 数组 
Sa 可 选 参数 。COUNT RECURSIVE (或 1) ， 如 选中 此 参数 ， 本 函数 将 递归 地 对 数 


组 计数 。 对 计算 多 维 数 组 的 所 有 单元 尤其 有 用 。 此 参数 的 默认 值 为 0 
本 实例 实现 取得 大 于 某 值 的 数据 的 SQL 语句 代码 如 下 : 
select count(*) as a from tb demo061 where $ POST[text] < outshop; 


实例 121 多 表 联 合 查 询 
( 实例 位 置 配套 资源 \SL\06\121 ) 
实例 说 明 


多 表 联 合 ee 以 解决 连接 或 简单 子 查询 难于 处 理 的 问题 。 运行 本 实例 ， 如 图 6.27 所 示 ， 
单 击 图 中 的 “合并 学 生 信息 ”按钮 即 可 将 “计算 机 系 ” 和 “数学 系 ” 的 学 生 信 息 合并 输出 。 


合并 学 生 信息 


2010-07-26 
2010-07-20 
2010-06-19 
2010-06-18 
2010-07-26 
2010-07-17 


图 6.27 多 表 联 合 查 询 
实现 过 程 
创建 脚本 文件 index.php， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “ 合 并 
生 信息 ”按钮 时 显示 如 图 6.27 所 示 的 内 容 。 核 心 代 码 如 下 : 


<?php 
这 $_GET[id] 一 "17{ /如 果 地 址 栏 衣 等 于 1 
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/返回 结果 集 
$rs =mysql query("select* from tb_demo074 student union select * from tb demo074 fasten"); 


2> 
| <table width="580px"><tr><td backeground-"pichead JPG"> 学 生 ID<td><td background="pic/head. 
”JPG"> 学 生 姓名 </td><td background="pic/headJPG"> 入 学 时 间 </td></tr> 
一 全 | <?php 
while($rst = mysql fetch row($rs){ /循环 输出 结果 


之 > 
! <tr><td background="pic/head.JPG"><?php echo S$rst[0];?></td><td background="pic/head.JPG"> 
| <?php echo $rst[1];?></td><td background="pic/head.JPG"><?php echo S$rst[2]:?></td></tr> 
| <2php 


| 利用 SQL 语言 中 的 关键 字 union 可 以 将 不 同 表 中 符合 条 件 的 数据 信息 显示 在 同一 列 
| 中 ，union 语句 的 使 用 格式 如 下 : 
| <query specification1> [,query specification2...] union [all] <query specification1> [,query specification2. ..] 
参数 说 明 : 
加 ”<query specification1>: 是 查询 规范 或 查询 表达 式 。 
回 union: 组 合 多 个 结果 集 并 将 其 作为 单个 结果 集 返 回 。 
all: 在 结果 集中 包含 所 有 的 行 ， 包 含 重复 行 。 


实例 122 ”left outer join 查询 


( 实例 位 置 : 配套 资源 \SL\06\122 ) 


| 实例 说 明 

| 如 果 要 包含 连接 的 两 个 表 中 的 不 匹配 行 ， 可 以 通过 左 连接 或 右 连接 的 方式 实现 。 运 生 
| 本 实例 ， 如 图 628 所 示 ， 单 击 图 中 的 “查询 ”按钮 即 可 将 员工 信息 表 中 所 有 记录 以 及 员工 
工资 表 中 与 员工 ID 相 匹配 的 记录 显示 出 来 。 


5o5ow 
ooo98o 
二 989998 
IG7t outer Join 震 询 33: 
A 
0 9 
查询 

小 杨 2010-07-26 2800 

小 潘 2010-07-26 2900 

中 刘 2010-07-26 3000 


图 6.28 left outer join 查询 


编写 脚本 文件 index.php， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “ 查 询 ” 
时 | .190 . 
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按钮 时 显示 如 图 6.28 所 示 的 内 容 。 核 心 代 码 如 下 : 


<2php 

$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); 

mysql select db("db _database06",$conn): 

mysql_query("SET NAMES UTF8"); 

if($ GET[id] ="1"){ 

S$rs = mysql_query("select * from 也 demo078_ wages right outer join tb_demo078_informaction on 
tb_demo078_ wages.id=tb_demo078_informaction.id "): 

> | 
<table width="580px" bgcolor="#F9DABB"> | 

<tr> 


<td style="color:#EFFFFF" align="center"> 员 工 姓名 </td> | 
<td style="color 考 FFFFF" align="center"> 入 职 时 间 </td> | 
<td style="color:#FFFFFF" align="center"> 员 工 工资 </td> 
</tr> 
<2php 
while($rst = mysql_fetch row($rs)){ 
?> 
<tr> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[3]:?></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[5]:?></td> 
<td bgcolor="#FFFFFF" align="center"><?php echo $rst[1]:?></td> 
</tr> 
<2php 
} 
ee 
</table> 
<?php 
} 


es 

技术 要 点 
左 连接 返回 的 查询 结果 包含 左 表 中 的 所 有 符合 查询 条 件 及 右 表 中 所 有 满足 连接 条 件 | 
的 行 ，MySQL 数据 库 中 使 用 左 连 接 的 语法 格式 如 下 : | 
select field 1[field2...] from tablel left [outer] join table2 on join_condition [where search_condition] 

参数 说 明 : 
回 left outer join: 表示 表 之 间 通 过 左 连接 方式 相互 连接 ， 也 可 以 简写 成 left join。 | 
回 ”on join_condition: 指 多 表 建 立 连 接 所 使 用 的 连接 条 件 。 | 
加 ”where search_condition: 可 选 参数 ， 用 于 设置 查询 条 件 。 | 


实例 123 ”right outer join 查询 | 

( 实例 位 置 : 配套 资源 \SL\06\123 ) | 

实例 说 明 
通过 右 连 接 可 以 将 右 表 中 满足 查询 条 件 的 记录 全 部 显示 出 来 并 显示 左 表 中 满足 连接 
“191 。 \ 


| 实现 过 程 
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条 件 的 记录 。 运 行 本 实例 ， 如 图 6.98 所 示 ， 单 击 图 中 的 “查询 ”按钮 即 可 将 员工 信息 表 中 
满足 连接 条 件 的 记录 及 员工 信息 表 中 所 有 记录 全 部 显示 出 来 。 


古河 田 本 双 2010-07-26 


图 6.29 right outer join 查询 


编写 脚本 文件 index.php， 启 动 MySQL 服务 ， 连 接 MySQL 数据 库 。 当 单 击 “ 查 询 ” 
按钮 时 显示 如 图 6.29 所 示 内 容 。 本 实例 核心 代码 如 下 : 


<2php 
$conn = mysql_connect("localhost","root","111") or die ("Connect MySQL False"); 
mysql_select_db("db_database06",$conn); 
mysql_query("SET NAMES UTF8"); 
这 $_GET[id] 一 "17{ 
S$rs = mysql query("select * from tb demo078_wages right outer join tb_demo078_informaction 
on tb_demo078_wages.id=tb_demo078_informaction .id "); 
?> 
<table width="580px" bgcolor="#3F9DD0"><tr><td style="color:#FFFFFF" align="center"> 员 工 姓 
名 </td><td style="color:#FFFFFF" align="center"> 员 工 性 别 </td><td style="color:#FFFFFF" align="center"> 
入 职 时 间 </td></tr> 
<2php 
while($rst = mysql fetch row($rs)){ 
?> 
<tr><td bgcolor="#FFFFFF" align="center"><?php echo S$rst[3]:?></td><td bgcolor="#FFFFFF" 
align="center"><?php echo S$rst[4];?></td><td bgcolor="#FFFFFF" align="center"><?php echo S$rst[5];?> 
</td></tr> 


<2php 
} 
} 
?> 
技术 要 点 


右 连接 返回 的 查询 结果 包含 左 表 中 的 所 有 符合 连接 条 件 以 及 右 表 中 所 有 满足 查询 条 
件 的 行 ，MySQL 数据 库 中 使 用 右 连接 的 语法 格式 如 下 : 
select field 1[field2...] from tablel right [outer] join table2 on join_condition [where search_ 
condition] 
参数 说 明 : 
right outer join: 表示 表 之 间 通 过 左 连接 方式 相互 连接 ， 也 可 以 简写 成 right join 。 
on join_condition: 指 多 表 建 立 连接 所 使 用 的 连接 条 件 。 


CD 
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where search_condition: 可 选 参 数 ， 用 于 设置 查询 条 件 。 


实例 124 利用 transform 分 析 数 据 


( 实例 位 置 : 配套 资源 \SL\06\124 ) 


实例 说 明 


利用 transform 可 以 动态 地 按照 类 别 或 分 组 统计 出 所 需要 的 数据 。 运 行 本 实例 ， 如 
图 6.30 所 示 ， 单 击 “ 统 计 ” 按 钮 即 可 按 月 份 将 不 同 种 类 图 书 的 数量 统计 出 来 。 


0 1263 200 
Ja 0 

Qe 958 | 
WB 1121 


图 630 利用 transform 分 析 数据 | 
实现 过 程 


有 具体 步骤 如 下 : 
(1) 创建 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 


<2php 

$conn=new com("adodb.connection'); 1/ 连接 数据 库 

$connstr="provider=microsoft.jet.oledb.4.0;data source=".realpath("./data/db_database06.mdb"); 

$conn->open($connstr); 

?> | 
(2) 执行 查询 ， 并 显示 查询 结果 ， 代 码 如 下 : | 

php 

include("conn.php"); // 包 含 数据 库 连 接 文 件 | 


S$rs=new com("adodb.recordset"); 
// 查 询 结 果 
S$rs->open("transform sum(number) as total select yyassort from tb_booksort where yyassort 
in (select yyassort from tb_booksort) group by yyassort pivot analysetime",$conn,3,1); 
if($rs->eofl| $rs->boD{ 
Ye 
<tr> 
<td height="25" colspan="8" bgcolor="yellow"><div align="center"></div></td> 
</tr> 
<?php 
} else{ 
while(!$rs->eof){ 


> 
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CS 
<t> 
<2php 
for($i=0;$1<=$rs->fields->count-1:$1++){ 
| ge 
食 扩 | | <td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields($1); echo 
A | iconv(‘gbk','utf-8',$f->value)?></div></td> 


<2php 
Nee | ) 

| > 
| </tr> 

<2php 

S$rs->movenext; 
1 
} 


?> 
</table></td> 
</tr> 
</table> 
<2php 
} 
?> 


| 技术 要 点 


| 本 实例 中 利用 transform 创建 交 义 表 查 询 ， 使 之 能 按 月 份 统 计 不 同名 称 图 书 的 数量 。 
| transform 的 语法 格式 如 下 : 
| transform aggfunction 

select statement 

pivot pivotfield [in (valuel[,valuel1]...[,;valuen])] 

参数 说 明 : 

aggfunction: 操作 所 选 数据 库 的 SQL 聚合 函数 。 
select statement: 要 执行 的 select 语句 。 
pivotfield: 希望 用 于 创建 查询 结果 集中 列 标题 的 字段 或 表达 式 。 
valuel...valuen: 用 于 创建 列 标题 的 固定 值 。 


| 


实例 125 使 用 格式 化 函数 转换 查询 条 件 的 数据 类 型 


( 实例 位 置 配套 资源 \SL\06\125 ) 


| 实例 说 明 


| 本 实例 将 利用 format0 函 数 实现 日 期 的 格式 化 输出 ， 由 于 该 函数 只 适用 于 Access 数据 
| 库 ， 所 以 本 实例 将 以 Access 作为 后 台数 据 库 ， 运 行 本 实例 ， 如 图 6.31 所 示 ， 单 击 图 中 的 
| “转换 ”按钮 即 可 将 内 容 显示 出 来 ， 并 将 日 期 格式 由 “xxxx-xx-xx” 转 换 为 “xxxx 年 xx 
| 月 xx 日 ” 格式。 
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俐 入 。 库存 生 ”天 别 。 ”进贡 日 央 
Ms nn 1 人 2907 有 ol 日 
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图 6.31 格式 化 函数 转换 查询 条 件数 据 类 型 


现 过 程 
具体 步骤 如 下 : 
(1) 创建 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
<2?php 
$conn=new com("adodb.connection"):; // 连 接 Access 数据 库 


$connstr="provider=microsoft.jet.oledb.4.0;data source=".realpath("./data/db_database06.mdb"); 
$conn->open($connstr): 
?> 


(2) 执行 查询 ， 并 将 日 期 转换 为 “xxxx 年 xx 月 xx 日” 格式， 代码 如 下 : 


<?php 
include("conn.php"); // 包 含 数 据 库 连接 文件 
S$rs=new com("adodb.recordset"); | 
S$rs->open("select bookname,syassort,price,number,format(analysetime,'yyyymmdd') as newdate | 
from tb_booksort",$conn,3,1); | 
if($rs->eofl| $rs->boD){ 
?> 
<tr> 
<td height="25" col "8" bgcolor="#EFFFFF"><div align="center"> 图 书 名 称 </div></td> 
</tr> 
<?php 
} else{ 
while(!$rs->eof) { 
> 
<tr> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(bookname); 
echo iconv("gbk","utf-8",$f->value);?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $=$rs->fields(price):echo ， 
iconv("gbk","utf-8",$f->value):?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(number): | 
echo iconv("gbk","utf-8", $f->value);?></div></td> 
<td height="25" bgcolor="#FFFFFF"><div align="center"><?php $f=$rs->fields(syassort); 
echo iconv("gbk","utf-8",$f->value);?></div></td> 
<td height="25" bgcolor="#EFFFFF"><div align="center"><?php $$rs->fields(newdate); 
echo iconv("gbk","utf-8",$f->value);?></div></td> 
</tr> 


“95s 


> 
</table></td> 
</tr> 
‘</table> 


<?php 
} 

| 技术 要 点 

format() 函 数 用 于 返回 variant(string), 其 中 含 一 个 表达 式 , 它 是 根据 格式 表达 式 中 的 格 
| 式 化 字符 串 来 确定 新 格式 输出 的 。 该 函数 的 语法 格式 如 下 : 

| format(expression[,format [,firstday of week [,firstweek] or year]]) 

expression: 必 选 参数 ， 是 任何 有 效 表 达 式 。 

format: 可 选 参数 。 是 有 效 的 命名 表达 式 或 用 户 自 定义 的 格式 表达 式 。 
firstday of week: 可 选 参数 。 表 示 一 个 星期 的 第 一 天 。 

firstweek of year: 可 选 参数 。 表 示 一 年 的 第 一 周 。 


实例 126 ”在 查询 中 使 用 日 期 函数 


( 实例 位 置 : 配套 资源 \SL\06\126 ) 


QARARARQRY 


实例 说 明 
本 实例 将 根据 员工 的 出 生日 期 自动 的 计算 员工 年 龄 并 显示 结果 , 运行 本 实例 ,如 图 6.32 
| 所 示 ， 单 击 图 中 的 “查询 ”按钮 即 可 将 所 有 员工 信息 显示 出 来 。 


在 查询 中 使 用 日 期 函数 
i 要 所 生日 查询 内 工 年 部 查 交 
员工 编号 姓名 性 别 年 齿 祖籍 
yaol 小 起 男 26 吉林 长 春 
ya 4 于 去 站 辽宁 沪 阳 
ya 4 科 男 了 吉林 四 二 
| 图 6.32 查询 员工 生日 信息 
| 实现 过 程 
具体 步骤 如 下 : 
(1) 创建 conn.php 文件 ， 实 现 与 数据 库 的 连接 ， 代 码 如 下 : 
<?php 
$conn=new com("adodb.connection"); /连接 数 据 库 


了 。196 。 
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$connstr="provider=microsoft.jet.oledb.4.0;data source=".realpath("./data/db_database06.mdb"); 
$conn->open($connstr); 
> 


(2) 执行 查询 ， 并 通过 函数 DateDiftO 计 算 所 有 员工 的 年 龄 ， 显 示 查 询 结果 ， 代 码 如 下 : 


<?php 
include("conn.php"); // 包 含 数据 库 连 接 文件 
S$rs=new com("adodb.recordset"):; 
/查询 结果 
Srs->open("select ygid,name,sex,address,DateDiff('yyyy',birthday,DATE()) as age from tb_worker", 


$conn,3,1); 
if($rs->eofl| $rs->bof) { 
?> 
<tr> 
<td height="25" colspan="8" bgcolor="#FFFFFF"><div align="center"></div></td> 
</tr> 
<?php 
jelse{ 
while(!S$rs->eof){ 
> 
<tr> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f=$rs-> 
fields("ygid"); echo iconv('gbk','utf-8',$f->value):?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $f=$rs-> 
fields("name"); echo iconv('gbk','"utf-8',$f->value);?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php 
$f=$rs->fields("sex"); echo iconv('gbk','utf-8',$f->value); ?></div></td> 
<td height="25" background="../089/images/head.JPG"><div align="center"><?php $= 
S$rs->fields("age"): echo iconv('gbk','utf-8',$f->value):?></div></td> 
<td height="25" background="../089/images/head.JPG">25<div align="center"><?php 
$f=$rs->fields("address"); echo iconv('gbk','utf-8',$f->value);?></div></td> 
</tr> 
<?php 
$rs->movenext: 
) 
?> 
</table></td> 
</t> 
</table> 
<2php 


2> 
技术 要 点 
DateDifftO 函 数 返 回 两 个 指定 日 期 的 时 间 间 隔 。 该 函数 的 语法 格式 如 下 : 
DateDiff(interval ,datel, date2 [,firstday of week [,firstweek of year]]) 


“07 


Ey 
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2 

参数 说 明 : 

回 interval: 必 选 参数 ， 字 符 吕 表达 式 ， 表 示 用 来 计算 datel 和 date2 的 时 间 间 陋 。 
回 datal,date2: 必 选 参数 ， 用 于 指定 具体 日 期 。 

回 firstday week， 可 选 参数 ， 指 定 一 年 的 第 一 周 的 常数 ， 如 果 未 指定 ， 则 以 包含 1 


月 1 日 的 星期 为 第 一 周 。 


多 学 两 招 : 
| 搜索 功能 是 一 个 很 主要 且 常 见 的 功能 。 一 个 好 的 搜索 功能 能 给 用 户 使 用 带 来 方便 。 接 
| 下 来 的 实例 127~ 实例 129 中 将 介绍 一 般 搜索 、 高 级 搜索 和 常用 搜索 的 实现 过 程 。 


实例 127 一 般 搜索 


( 实例 位 置 : 配套 资源 \SL\06\127 视频 位 置 配套 资源 \SP\06\127 ) 


| 实例 说 明 
站 内 搜索 有 很 多 种 ， 程 序 开发 人 员 可 以 根据 站 内 信息 的 多 少 来 设置 搜索 的 范围 大 小 。 
| 本 实例 主要 介绍 一 般 搜 索 功 能 是 如 何 实现 的 。 本 实例 主要 应 用 SQL 语言 中 select 语句 的 模 
| 糊 查询 (like〉 完 成 站 内 搜索 。 运 行 本 实例 ， 在 文本 框 中 输入 要 查询 的 关键 字 ， 然 后 单 击 
“搜索 ”按钮 ， 将 检索 指定 条 件 的 记录 信息 并 输出 到 浏览 器 ， 运 行 结果 如 图 6.33 所 示 。 


| Ed 


开始 完 主 手 队 
、 训 用 ， 又 可 查询 参考 的 类 据 库 交 图 全 


EU 清太 
热门 999 个 流 和 中 首 刘 不 统 


| 图 6.33 一 般 搜索 运行 结果 

| 实现 过 程 

| 具体 步骤 如 下 : 

(1) 建立 与 数据 源 的 连接 ， 代 码 如 下 : 

<2?php 
$link=mysql_connect("localhost","root"."111"): // 设 置 数 据 库 连接 参数 
mysql select_db("db_database06",$link): // 选 择 数 据 库 
mysql query("set names gb2312"): // 设 置 编 码 格式 


?> 


(2) 添加 form 表单 、 文 本 框 ， 并 设置 相关 属性 值 ， 代 码 如 下 : 


<form name="myform" method="post" action=""> 
| <input name="txt_t]" type="text" 1d="txt_t]" size="50"> 
a 。198 。 
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<input name="submit" type="submit" id="submit" value=" 搜 索 " onClick="return Mycheck0:" > 


</form> 
(3) 通过 select 语句 中 的 like 关键 字 对 输入 的 关键 字 进 行 模糊 查询 ， 程 序 代码 如 下 : 
<?php 
ifisset($_ POST["submit"])){ // 狮 断 用 户 是 否 执行 提交 操作 
Set_ ttnim($ POST["tExt_t]); // 获 取 去 除 连 续 空白 的 POST 传递 值 
$sql=mysql query("select * from tb book where synopsis like '%$txt tj%' or bookname like 
"6$txt tj%' order by id dese"); /执行 数据 库 通配符 查询 操作 
Sinfo=mysql fetch array($sql); // 遍 历 结果 集 
Bb 
iflisset($info)) { 
do{ /循环 输出 查询 结果 
> 
<tr> 


<td height="23">&nbsp;<font color="#CC0033"> © &nbsp;<?php echo S$infofbookname]:?> 
</font></td> 
</tr> 
<tr> 
<td>&nbsp:&nbsp:&nbsp:&nbsp:&nbsp;<?php echo $info["synopsis"];?></td> 

</tr> 

<?php }while($info=mysql_fetch_array($sqD); /循环 输 出 遍历 结果 集 

}else{ 

> 

<tr> 

<td> 对 不 起 ， 您 检索 的 信息 不 存在 ! </td> 

</tr> 
<?php 
} 


?> 
技术 要 点 


本 实例 在 进行 数据 查询 时 主要 应 用 select 语句 中 的 like 关键 字 和 or 关键 字 , 进行 多 条 
件 模糊 查询 。 
like 属于 较 常 用 的 比较 运算 符 ， 通 过 它 可 以 实现 模糊 查询 。 它 有 两 种 通配符 :“%” 和 
下 划 线 “_”。 
“%” 可 以 匹配 一 个 或 多 个 字符 ， 而 “_” 只 匹配 一 个 字符 。 
例如 ， 查 找 所 有 第 二 个 字母 是 “h” 的 图 书 ， 代 码 如 下 : 
select * from tb_mrbook where bookname like(’_h%"); 


多 学 两 招 : 
“p” 和 “入 ”都 算 做 一 个 字符 ， 在 这 一 点 上 英文 字母 和 中 文 没 有 什么 区 别 。 


like 运算 符 用 于 设置 与 查询 关键 字 进 行 模式 匹配 。 例 如 ， 要 查询 tb_book 表 中 内 容 中 
含有 “PHP” 的 记录 ， 其 程序 代码 如 下 : 
select * from tb_book where synopsis like '"%PHP%' or bookname like '%PHP%' 
“99. 
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移 
上 面 代码 中 使 用 的 是 “%” 通 配 符 ，select 语句 的 通配符 有 以 下 4 种。 
(1) %〔 百 分 号 ) 可 以 匹配 任意 个 字符 。 
| (2) _0 可 以 匹配 任意 一 个 字符 。 
天 | (3) []0 用 来 限定 任何 一 个 单一 字符 介 于 赋值 的 范围 或 集合 
Re (4) INO 关 键 字 用 于 过 滤 记 录 是 否 为 IN 表达 式 中 任何 一 个 。 例如 ， 将 tb book 表 中 
oo 所 有 PHP 或 JSP 的 图 书信 息 显示 出 来 的 代码 如 下 。 
SELECT* FROM tb _ book WHERE resume JINCOPHP',JSP) 
| or 关键 字 用 于 联合 多 个 条 件 进行 查询 ， 只 要 满足 多 个 查询 条 件 中 的 任意 一 个 ， 这 样 的 
| 记录 就 会 被 查询 出 来 。 只 有 那些 不 满足 查询 条 件 中 任意 一 个 的 记录 才 会 被 排除 。or 关键 字 
| 的 语法 如 下 : 
| result = expressionl or expression2 [ ... and expression n ] 
参数 说 明 : 
result: 任意 数值 变量 。 
expression1: 任意 表达 式 。 
expression2: 任意 表达 式 。 
expression n: 任意 多 个 表达 式 。 


实例 128 ”高 级 搜索 


( 实例 位 置 : 配套 资源 \SL\06\128 ) 


| 


”实例 说 明 

在 开发 搜索 网 站 时 , 为 了 方便 用 户 浏览 网 站 信息 , 需要 添加 一 些 相关 信息 的 搜索 功能 
| 本 实例 就 是 一 个 搜索 网 站 ， 该 网 站 含有 大 量 的 数据 信息 ， 因 此 设置 高 级 搜索 功能 。 高 级 搜 
| 索 主要 通过 复合 条 件 查询 实现 搜索 功能 。 运 行 本 实例 ， 在 “请 输入 要 检索 的 全 部 名 称 ” 文 
| 本 框 和 “请 输入 要 检索 的 部 分 内 容 ” 文 本 框 中 输入 关键 字 ， 在 “请 选择 要 搜索 的 类 型 ”下 
| 拉 列 表 框 中 选择 要 搜索 的 类 型 ， 然 后 单 击 “高 级 搜索 ”按钮 ， 对 指定 条 件 的 记录 进行 检索 
| 并 输出 结果 集 到 浏览 器 ， 运 行 结果 如 图 6.34 所 示 。 


避 Pi 淮 据 库 各 纺 开 发 定 全 手册 
直 书 是 一 二 本 可 节 避 、 全 用 只 可 去 记 湖 考 的 帮手 兴国 书 ,书店 汇集 了 作者 乡 年 未 从 事项 目 开发 
的 全 验 之 芋 华 。 很 多 全 全都 提 信 自作 者 从 事 过 的 安 际 工作 项 目 - 


| 图 634 高 级 搜索 
J “9300 
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具体 步骤 如 下 : 
(1) 添加 form 表单 、 文 本 框 、 下 拉 列 表 ， 并 设置 其 相关 属性 值 ， 关 键 代码 如 下 : 


<form name="myform" method="post" action=""> 

<input name="txt_name" type="text" id="txt_name" size="20"> 

<input name="txt_content" type="text" id="txt_content" size="20"> 

<select name="select"> | 
<option value="ASP">ASP</option> | 
<option value="PHP" selected>PHP</option> 
<option value="JSP">JSP</option> | 

</select> 

<input type="submit" name="submit" value=" 高 级 搜索 " onClick="return Mycheck0:"> 

</form> 


(2) 应 用 JavaScript 脚本 自 定义 一 个 Mycheck0 函 数 ,实现 对 表单 提交 信息 进行 验证 ， 
代码 如 下 : | 


<script language="javascript"> 


function chkinput(form){ 
if(form.txt_name.value—""){ 
alert(" 请 输入 要 检索 的 全 部 名 称 !"); 
form.txt_name.focus(); 
retum(false); 
} 
if(form.txt_content.value—""){ 
alert(" 请 输入 要 检索 部 分 的 内 容 !"); 
form.txt_content.focus(; 
return(false); 
return(true); 
} 
</script> 


(3) 获取 表单 中 提交 的 查询 关键 字 ， 应 用 like 比较 运算 符 和 and 关键 字 完 成 多 条 件 | 
的 模糊 查询 。 其 关键 代码 如 下 : | 
<2php | 
ifisset($_ POST["submit"])){ /判断 提交 按钮 是 否 设置 
Stxt_name=trim($ POST["txt_name"]): // 获 取 查询 关键 字 | 
S$txt_content=trim($_POST["txt_content"]); | 
$type=$_POST["select"]: | 
$sql=mysql_query("select * from tb mrbook where bookname like '%$txt name®%' and synopsis 

like '%$txt_content%%' and resume like '%$type%'order by id desc"):// 执 行 多 条 件 的 模糊 查询 
$info=mysql fetch_array($sqD); /获取 查询 结果 集 | 


技术 要 点 
本 实例 主要 应 用 复合 条 件 查询 ， 完 成 高 级 搜索 功能 。 应 用 and 关键 字 对 两 个 表达 式 进 | 
。201。 \ 
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ga 
| 行 罗 辑 与 运算 ， 来 实现 高 级 搜索 。 
| and 关键 字 用 于 联合 多 个 条 件 进行 查询 。 使 用 and 关键 字 时 ， 只 有 同时 满足 所 有 查询 
“| 条 件 的 记录 会 被 查询 出 来 。 如 果 不 满足 这 些 查 询 条 件 中 的 任意 一 个 ， 则 这 样 的 记录 将 被 排 
国内 除 。and 关键 字 的 语法 如 下 


result = expressionl and expression2 [ ... and expression n ] 
| 参数 说 明 : 

result: 任意 数值 变量 。 

expression1: 任意 表达 式 。 

expression2: 任意 表达 式 。 

expression n: 任意 多 个 表达 式 。 

| 另外 , 本 实例 还 支持 数据 库 数据 检索 描 红 技术 , 即 对 查询 到 的 数据 标题 进行 描 红 操作 。 

| 其 实现 原理 是 : 当 用 户 单 击 “ 搜 索 ” 按 钮 对 数据 搜索 时 ， 将 返回 的 数据 添加 标签 <font>， 

| 并 通过 <font> 标 签 设 置 返回 数据 的 颜色 为 红色 。 其 关键 代码 如 下 : 

| <font color="#CC0033"> © &nbsp:<2php echo $info["bookname"]:2></font> 


加 网 罗网 


实例 129 程序 员 搜 索引 党 


( 实例 位 置 : 配套 资源 \SL\06\129 ) 


实例 说 明 
当 提 到 “搜索 引擎 ”这 个 名 词 时 ， 自 然 会 想到 百度 、 谷 歌 等 一 些 非常 著名 的 搜索 引 
| 擎 网 站 。 本 实例 中 将 介绍 一 个 简单 搜索 引擎 网 站 的 制作 。 其 常用 搜索 主要 包括 人 才 网 站 
| 搜索 、IT 企业 故事 搜索 、IT 企业 风云 人 物 简 介 搜索 、 常 用 术语 搜索 、 开 发 语言 简介 搜索 、 
| 编程 网 站 搜索 、 图 书 资源 搜索 、 创 业 故 事 搜索 。 其 中 开发 语言 搜索 的 运行 结果 如 图 6.35 
| 所 示 。 


图 6.35 程序 员 搜索 引擎 
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AN 
实现 过 程 
具体 步骤 如 下 : | 
(1) 创建 connphp 文件 ， 设 置 数 据 库 连接 参数 ， 完 成 与 指定 数据 库 的 连接 操作 。 其 | 
代码 如 下 : | 
<?php 
S$link=mysql_connect("localhost","root","111"); /设置 数据 库 连 接 参数 
mysql_select_db("db_database06",$link); // 选 择 数 据 库 
mysql query("set names gb2312"); /设置 数据 库 编码 格式 
?> 


(2) 创 建 index.php 文件 , 应 用 mysql_query0 函 数 执行 SQL 查询 语句 , 应 用 do...while 
循环 输出 mysql_fetch_array0 函 数 获取 的 查询 结果 集 。 并 且 创 建 自 定义 函数 chinesesubstr() 
对 数据 的 内 容 进行 截取 输出 。 其 关键 代码 如 下 : 

<table width="555" border="0" cellpadding="0" cellspacing="0"> 
<2php 
$sql=mysql_ query("select distinct resume,info from tb_books order by id dese"):// 执 行 查询 语句 
$info=mysql_fetch_array(SsqD; // 获 取 结 果 集 
if($info){ 
do{ // 循 环 输出 结果 集 
?> 
<tr> 
<td width="555" height="23"> 
<font color="#CC0033">©Y &nbsp;&nbsp; 
<a href="info.php?resume=<?php echo S$info["resume"]:?>"><?php echo $info 
["resume"];?></a> 
</font> 
</td> 
</tr> 
<tr> 
<td><?php echo chinesesubstr(Sinfo["info"],0,300);if(strlen(Sinfo["info"])>300){echo "...";}?> 
</td> 
</tr> 
<2php 
}while($info=mysql _fetch_array($sqD): 
}else{ 
?> 
<tr> 
<td> 对 不 起 ， 您 检索 的 信息 不 存在 ! </td> 
</t> 
<?php 
} 
> 
</table> 


(3) 单 击 index.php 文件 中 设置 的 类 别名 称 超 链接 ， 将 跳 转 到 info.php 页 ， 根 据 超 链 
接 传递 的 类 别名 称 执行 查询 语句 ， 查 询 出 符合 条 件 的 图 书信 息 。 
“203= 
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本 实例 意 在 让 读者 了 解 简单 的 搜索 引擎 , 同时 让 读者 了 解 PHP 数据 库 编 程 的 基本 步 又 
以 及 基本 的 函数 应 用 。 
(1) 通过 mysql_connect() 函 数 连接 MySQL 服务 器 。 
(2) 通过 mysql_select_db0 〇 函数 选择 指定 数据 库 。 
(3) 通过 mysql_query0 函 数 设置 数据 库 编码 格式 。 
(4) 通过 mysql_query0 函 数 执 行 SQL 语句 。 
(5) 通过 mysql_fetch_array0 函 数 获 取 查 询 结 果 集 。 
(6) 通过 mysql_close0 函 数 关 闭 数据 库 。 
在 本 实例 中 还 引入 了 一 个 自 定义 函数 ， 对 中 文字 符 串 进行 截取 操作 。chinesesubstr() 
函数 的 语法 如 下 : 
function chinesesubstr($str,$start,$len){ //$str 指 的 是 字符 串 , $start 指 的 是 字符 串 的 起 始 位 置 , $len 


指 的 是 长 度 
S$tmpstr=""; 


$strlen=$start+$len;// 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i=0;$i<$strlen:$i++){ // 通 过 for 循环 语句 ， 循 环 读 取 字符 串 
ifkord(substr($str,$i,1))>0xa0){// 如 果 字 符 串 中 首 个 字 节 的 ASCII 序数 值 大 于 0xa0， 则 表示 
为 汉字 
$tmpstr.=substr($str,$i,2); /每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 
人 /变量 自 加 1 
jelsef /如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
S$tmpstr.=substr($str,$1,1):; 
} 
} 
return $tmpstr; /| 输出 字符 串 
} 


应 用 此 函数 的 目的 是 避免 在 截取 中 文字 符 串 时 出 现 乱码 。 其 原理 是 : 对 截取 字符 串 的 
ASCII 值 进行 判断 ， 如 果 值 大 于 “0xa0”， 说 明 是 中 文 ， 那么 以 2 字 节 为 截取 长 度 对 原 字符 
串 执 行 截取 操作 ， 否 则 应 用 substr0 函 数 正常 截取 字符 串 。 
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诬 


字符 串 高 级 处 理 


本 章 读 者 可 以 学 到 如 下 实例 : 


例 130 
例 131 
例 132 
例 133 
例 134 
例 135 
例 136 
例 137 
实例 138 
实例 139 
实例 140 
实例 141 
实例 142 
实例 143 
实例 144 
实例 145 
实例 146 
实例 147 
实例 148 
实例 149 


将 


治 沟 


治 澡 


归 史 


准将 


2 


时 


统计 帖子 标题 的 长 度 
购物 车 中 数据 的 读 取 

查询 关键 字 描 红 

统计 查询 关键 字 的 出 现 次 数 

去 除 帖 子 标题 的 首尾 空格 
验证 电话 号 码 的 格式 是 否 正确 
验证 E-mail 地 址 格式 是 否 正确 
超 长 文本 的 分 页 输出 

统一 上 传 文件 名 称 的 大 小 写 
货币 数据 的 格式 化 输出 

统一 英文 注册 用 户 首 字母 大 小 写 
解决 用 substrO 函 数 对 中 文字 符 串 截取 时 乱码 
将 元 素 中 指定 位 置 的 索引 替换 
统计 数组 元 素 的 个 数 

去 除数 组 中 的 重复 元 素 

判断 字符 囊 中 是 否 存 在 指定 子囊 
合并 数组 

拆 分 数组 

将 时 间 和 日 期 转换 为 时 间 鹤 

网 页 阐 钟 


需 


| 做 好 铺垫 。 本 实例 通过 strlen0 函 数 获取 帖子 标题 的 内 容 : 坝 目 科技 ~ 

| 长度。 注意 ， 由 于 页 面 采用 UTF-8 编码 格式 ， 所 以 ME 
| 一 个 中 文字 符 串 长 度 是 3 个 字 节 ， 如 果 页 面 采用 
| GB2312 编码 格式 ,那么 一 个 中 文字 符 串 长 度 是 2 个 
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实例 130 统计 帖子 标题 的 长 度 


( 实例 位 置 : 配套 资源 \SL\07\130 ) 


实例 说 明 
统计 字符 串 长 度 一 般 是 为 了 给 其 他 函数 的 应 用 


标题 :明日 科技 


标题 长 度 为 12 个 字 想 


| 字 节 。 其 运行 结果 如 图 7.1 所 示 。 图 7.1 统计 帖子 标题 的 长 度 
| 实现 过 程 


创建 名 称 为 “index.php” 的 PHP 脚本 文件 ， 当 用 户 单 击 “ 发 布 ” 按钮 时 ， 利 用 strlen0 


| 函数 获取 通过 POST 方法 接收 到 的 数据 长 度 ， 其 代码 如 下 ， 


| 技术 要 点 


<2?php 
if(lempty($_POST["sub"])){ // 通 过 POST 方式 传 参 
echo "标题 长 度 为 ".strlen($_POST["text"])." 个 字 节 "; // 获 取 字 符 串 长 度 


strlen0 函 数 用 于 获取 字符 串 的 长 度 。 其 语法 如 下 : 
int strlen ( string stD; 
参数 str: 指定 字符 串 。 


| 多 学 两 招 ， 


| 用 strlen0 函 数 获 取 字 符 串 长 度 时 ， 如 果 字 符 串 中 存在 空格 ， 则 空格 也 会 被 计算 在 内 。 


实例 131 购物 车 中 数据 的 读 取 


( 实例 位 置 : 配套 资源 \SL\07131 ) 


| 实例 说 明 


SESSION 购物 车 的 设计 原理 : 当 用 户 登 录 网 站 时 ， 系 统 将 为 每 个 用 户 分 配 两 个 
SESSION 变量 $producelist 和 $quatity, 分 别 用 来 存储 用 户 放 入 购物 车 中 的 商品 ID 和 商品 数 
量 ， 将 @ 作 为 分 隔 符 ， 实 现 将 多 个 ID 值 同 时 保存 在 一 个 Sproducelist 变量 中 。 例 如 ， 用 户 
分 别 将 耳 为 1、2、3 的 商品 放 入 购物 车 中 ， 这 时 SESSION 变量 $producelist 的 值 应 该 为 
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角 日 图 书 。 ”明日 软件 优惠 商品 。 团购 商品 商品 排行 


3400 元 3400 元 


4500 元 4500 元 


合计 : 7900 元 


pyright 四 1999-2010 吉林 省 明日 科技 有 限 公司 


图 7.2 购物 车 中 商品 展示 
实现 过 程 
创建 名 称 为 “gouwu-php” 的 PHP 文件 ， 应 用 explode0 函 数 读 取 SESSION 变量 中 存 | 
储 的 字符 串 ， 并 返回 数组 元 素 ， 然 后 ， 应 用 for 循环 语句 读 取 数组 中 的 元 素 值 ， 将 获取 的 | 
元 素 值 作为 条 件 ， 执 行 查询 语句 ， 从 数据 库 中 读 取 数 据 ， 最 后 ， 完 成 商品 金额 的 计算 , 并 | 
输出 购买 商品 信息 。 
关键 代码 如 下 : 
<2php 
S$total=0; 


$array=explode("(@",$_SESSION[" producelist"]); ”// 读 取 SESSION 中 存储 的 商品 D， 返 回 数组 | 
$arrayquatity=explode("(@",$_SESSION["quatity"]); // 读 取 SESSION 中 存储 的 商品 数量 , 返回 数组 | 


for($i=0;$i<count($array)-1:$i++){ //for 循环 获取 商品 的 数量 和 ID 
S$id=$array[$i]; // 获 取 商 品 人 D 
$num=$arrayquatity [$i]; // 获 取 商 品 数量 
i1f($id!=""){ // 判 断 是 否 存在 指定 的 商品 

$sql=mysql_query("select * from tb_shangpin Where id=".$id."",$conn); 

S$info=mysql fetch array($sql); // 获 取 查 询 结 果 

S$totall=$num*$info["huiyuanjia"]: /计算 商品 金额 

$total+=$totall; /计算 总 的 金额 

$_SESSION["total"]=$total: // 为 SESSION 变量 赋值 
es 

技术 要 点 


SESSION 购物 车 的 设计 原理 : 当 用 户 登录 网 站 时 ， 系 统 将 为 每 个 用 户 分 配 两 个 | 
SESSION 变量 ， 它 们 分 别 是 Sproducelist 和 Squatity， 二 者 分 别 用 来 存储 用 户 放 入 购物 车 中 | 
的 商品 ID 和 商品 数量 ， 将 @ 作 为 分 隔 符 ， 实 现 将 多 个 ID 值 同时 保存 在 一 个 Sproducelist | 
变量 中 。 例 如 ,用 户 分 别 将 ID 为 1、.2,.3 的 商品 放 入 购物 车 中 ,这 时 SESSION 变量 Sproducelist | 
的 值 应 该 为 “1@2@3@”。 另 外 ， 如 果 需 要 设置 购买 某 种 商品 数量 时 ， 应 该 将 带 有 商品 ID | 
的 变量 SSESSION ["producelist"] 与 商品 数量 SSESSION ["quatity"] 中 的 位 置 一 一 对 应 。 如 打 | 
算 更 改 ID 为 2 的 商品 数量 3 个 ， 只 需 将 SSESSION ["producelist"] 中 “1@2@3@” 了 DD 为 2 | 
所 对 应 SSESSION ["quatity "] 的 位 置 改 为 3， 即 “1@3@1@”， 来 实现 购物 车 中 某 种 商品 数 | 
量 的 更 改 。 | 
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多 学 两 招 : 


SESSION 和 Cookie 一 样 存在 其 生命 周期 ,如 用 户 需 要 更 改 SESSION 存在 的 时 间 长 度 ， 
可 以 通过 应 用 session set_cookie params() 函 数 来 延长 SESSION 的 生命 周期 。 


实例 132 ”查询 关键 字 描 红 


( 实例 位 置 : 配套 资源 \SL\07\132 视频 位 置 : 配套 资源 \SP\O7\132 ) 


实例 说 明 
查询 关键 字 描 红 在 百度 、 谷 歌 等 
的 内 容 。 运 行 结果 如 图 7.3 所 示 。 


搜索 引擎 中 是 非常 实用 的 ， 通 过 它 可 以 凸显 出 要 查找 


纺 编 种 闻 归 服务 社区 


社区 首页 | 先生 各 让 。 信和 村 括 。 服务 国信。 生 灾 易 了 各 。 办 天 。 只 二 而。 入 到 中 让 


仿 和 说 划 
2009 


你 的 私人 编程 专家 


hy 进 行 并 站 开发 的 初中 用 放 着 ， 一 些 家 例 台 
和 a 有 


图 7.3 查询 关键 字 描 红 


现 过 程 


应 用 str_ireplace0 函 数 ,将 指定 输入 的 内 容 用 带 有 CSS 属性 的 font 标签 的 原 内 容 蔡 换 ， 
来 实现 字符 串 关键 字 的 描 红 。 其 关键 代码 如 下 : 


<2php 
$string=str_ireplace($txt tj."<font 


color=#FF0000'><strong>$txt_tj</strong></font>",$info[bookname]): 


echo $string; 

?> 

<2php 

S$strings=$ POST["txt 1"]; 


/作为 加 入 CSS 标签 的 替换 内 容 


$string=str_ireplace($_ POST["txt 4"],"<font color='#FF0000'><strong>$strings</strong></font>",$info 


[synopsis]); 
echo $string; 
0 


技术 


Pr 


// 输 出 描 红 的 字符 串 


查询 关键 字 描 红 关 键 就 是 应 用 str_ireplace0) 函 数 对 提交 的 关键 字 进 行 替 换 ， 即 首先 为 
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关键 字 进 行 包装 ， 然 后 应 用 str_ireplace0 函 数 用 包装 后 的 关键 字 替 换 掉 原来 未 包装 的 关键 
字 。 其 包装 的 手法 就 是 将 关键 字 的 字体 加 粗 ， 并 设置 为 红色 。 


多 学 两 招 : 
用 strlen0 却 数 获 取 字 符 串 长 度 时 ， 如 果 字 符 囊 中 存在 空格 ， 则 空格 也 会 被 计算 在 内 。 


实例 133 ”统计 查询 关键 字 的 出 现 次 数 | 


( 实例 位 置 : 配套 资源 \SL\07\133 ) 


实例 说 明 

在 站 内 搜索 中 ， 我 们 往往 需要 列 出 符合 条 件 的 关键 字 有 多 少 个 。 本 实例 通过 字符 串 函 | 
数 substr_count0 统 计 查 询 关 键 字 的 出 现 次 数 ， 运 行 结果 如 图 7.4 所 示 。 | 
被 搜索 的 文本 认 PHP 作 为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 二 从 j994 年 放生 至 今 已 | 
被 2000 多 万 个 动态 网 站 采用 ， 全 球 知名 互联 网 公司 Giogle、Yahoo、cBay 和 中 国 知名 网 站 新 浪 、 百 度 、 ! 
阿里 巴巴 等 均 采用 ?HP 技术 1 ! 
关键 了 , PrP | 


了 HP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 多 万 个 动态 网 
站 采用 ， 全 球 知名 五 联网 公司 Google。、Yahoo、*eEay 和 中 国 知名 网 站 新 浪 、 百 度 、 阿 里 巴巴 等 均 采 用 
PHP 技术 ) 


关键 字 出 现 2 次; 


图 7.4 统计 查询 关键 字 的 出 现 次 数 

实现 过 程 | 
创建 脚本 文件 index.php。 首 先 ， 定 义 字 符 串 变量 ， 编 写 form 表单 。 当 单 击 “ 搜 索 ” 
按钮 时 ， 利 用 substr_count() 函 数 输 出 指定 字符 串 子 串 的 出 现 次 数 。 其 代码 如 下 : 


<2php | 
echo "<a style='font-size:20px; color:#000000> 被 搜索 的 文本 : </a>"; /定义 字符 串 输出 | 
$str= "PHP 作为 全 球 最 普及 、 应 用 最 广泛 的 互联 网 开发 语言 之 一 ， 从 1994 年 诞生 至 今 已 被 2000 | 
多 万 个 动态 网 站 采用 ， 全 球 知名 互联 网 公司 Google、Yahoo、eBay 和 中 国 知 名 网 站 新 浪 、 百 度 、 阿 里 巴 
巴 等 均 采 用 PHP 技术 !"; 
cho $str."<br>"; 
2 
<form action ="" method="post"> /表单 
关键 字 : <input type="text" name="text"><input type="submit" name="sub" value =" 搜 索性 
</form> 
</body> 
</html> 
<?php 
这 !empty($_POST["sub"])){ // 通 过 POST 方式 传递 参数 
$a = "<b style='colorred:font-size:18px:>".$ POST["text"]."</b>": // 蔡 换 后 的 字符 串 
echo str_replace("$ POST["text"]",$a,$str)."<br>"; // 蔡 换 字符 串 
/统计 关键 字 出 现 次 数 
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多 学 两 招 
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a 


echo "关键 字 出 现 <b style='color:red:font-size:22px:'>".substr_count($str.$_POST["text"])."</b> 次 。": 


四 
| 了 > 
| 技术 要 点 


本 实例 通过 substr_count0 函 数 检 索 字 符 串 子 串 的 出 现 次 数 。substr_count0 函 数 的 语法 
如 下 : 


int substr_count ( string haystack, string needle ) 
参数 说 明 : 
回 string haystack: 源 字符 串 。 
回 string needle: 字符 串 子 串 。 


| substr_countO 是 一 种 类 似 全 文 检索 的 函数 。 它 的 原理 是 检索 查找 匹配 的 字符 串 ， 并 返 
| 回 匹配 的 次 数 。 
实例 134 ”去除 帖子 标题 的 首尾 室 格 
( 实例 位 置 : 配套 资源 \SLWT7\134) 
实例 说 明 
| 用 户 在 编写 代码 时 ， 也 许 会 在 不 经 意 间 多 了 一 个 本 


| 或 多 个 空格 ， 以 至 程序 无 论 怎么 调试 都 无 法 正常 运行 。 
| 本 实例 通过 trimO 函 数 实现 去 除 帖 子 标题 的 首尾 空格 ， 人 
| 运行 结果 如 图 7.5 所 示 。 


未 去 掉 空 格 前 字符 长 度 为 18 个 字 节 


注意 ， 由 于 页 面 采用 UTF-8 编码 格式 ,所 以 一 个 中 。。 图 75 去除 了 征 的 首 必 和 罗 


| 文字 符 串 的 长 度 是 3 个 字 节 ， 而 一 个 空格 的 长 度 是 2 个 


字 节 ， 所 以 本 实例 去 掉 空 格 前 的 长 度 为 18 个 字 节 ， 去 掉 空 格 后 的 长 度 为 12 个 字 节 。 读者 可 
以 自行 创建 一 个 GB2312 编码 格式 的 网 页 , 然后 实现 此 功能 , 比较 一 下 它们 之 间 有 什么 不 同 。 
实现 过 程 
创建 PHP 脚本 文件 。 当 用 户 单 击 “提交 ”按钮 时 ， 利 用 strlen0 函 数 获取 函数 的 长 度 ， 

然后 应 用 trim0 函 数 和 strlen0 函 数 的 联合 操作 ， 实 现 输 出 在 去 除 首 尾 空格 的 前 后 字符 串 的 
长 度 。 其 代码 如 下 : 

<?php 

这 !empty$_ POST["sub"])){ /通过 POST 方式 传递 参数 

echo "未 去 掉 空 格 前 字符 长 度 为 ".strlen($_POST["text"])." 个 字 节 <br>"; // 输 出 结果 


echo "去 掉 空 格 后 字符 长 度 为 ".strlen(trim($_POST["text"]))." 个 字 节 "; // 输 出 结果 


> 
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技术 要 点 | 
在 PHP 中 去 除 字符 串 的 首尾 空格 ， 可 以 使 用 函数 tim0 实 现 。Trim0 函 数 的 语法 如 下 ; 
string trim(string str): | 


参数 string str 为 需要 过 滤 空 格 的 字符 串 。 


多 学 两 招 
PHP 还 提供 了 单纯 去 除 字符 事 左 边 空格 的 函数 ltrim 0 和 单纯 去 除 右边 空格 的 函数 | 
rtrim(). | 


实例 135 ”验证 电话 号 码 的 格式 是 否 正 确 


( 实例 位 置 : 配套 资源 \SL\07\135 视频 位 置 配套 资源 \SP\07\135 ) 


实例 说 明 

表单 注册 时 往往 要 求 用 户 书写 座机 电话 号 码 , 而 
座机 电话 号 码 是 由 12 位 或 11 位 数字 组 成 的 , 所 以 一 
定 要 对 电话 号 码 的 位 数 和 格式 进行 限制 。 本 实例 通过 
正则 表达 式 和 正则 表达 式 函 数 preg_match0 实 现 对 电 
话 号 码 格式 的 验证 ， 运 行 结果 如 图 7.6 所 示 。 | 
实现 过 程 图 7.6 “验证 电话 号 码 的 格式 是 否 正 确 | 

创建 index.php 文件 。 创 建 表单 ， 并 在 页 面 的 表单 中 设置 用 户 文本 框 和 “提交 ”按钮 ， 
当 用 户 单 击 “ 提 交 ” 按 钮 时 ， 通 过 正则 表达 式 函 数 preg_match() 对 用 户 在 文本 框 输 入 的 电 | 
话 号 码 进行 验证 ， 并 输出 相关 提示 ， 其 代码 如 下 


oa31-822223 


<2php 
这 !empty($_POST[sub]){ /判断 是 否 存在 传递 参数 
if(preg_match("/(\d{3}-)Qd{8})$IQd{4}-)Qd{7})$/",$_POST['text])){// 正 则 表达 式 验证 
include("inc.php"); // 包 含 信息 提示 页 
show_error(" 信 息 提示 "," 格 式 正 确 ","index.php"); // 调 用 自 定义 函数 输出 提示 信息 
}else{ 
include("inc.php"):; 
show_error(" 信 息 提示 "," 格 式 错误 ","index.php"); // 调 用 自 定义 函数 输出 提示 信息 
上 
} 
?> 
脚下 留神 : 


这 里 给 出 的 实例 仅 用 来 判断 区 号 为 4 位 的 电话 号 码 。 当 电话 号 码 的 区 号 为 3 位 时 ， 如 | 
“010-12345678”， 则 不 能 通过 正则 表达 式 的 验证 。 | 
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| 技术 要 点 
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(1) preg_match0: 进行 正则 表达 式 匹 配 。 
intpreg match ( string pattern, string subject [, array matches [, int flags]]); 
(2) 正则 表达 式 : 固定 总 位 数 为 11 位 或 12 位 的 座机 电话 。 
/0d{3}-)0d{8))8IQd{4}-)Qd{7})8/; 


| 多 学 两 招 : 


正则 表达 式 “/Qd{3}-)Qd{8})SIQd{4}-)(qd{7})$/” 是 根据 新 式 电话 号 码 设置 的 ， 老 式 的 


| 座机 电话 是 10 位 数字 组 成 的 。 


| 实例 说 明 


| 都 有 自己 的 E-mail 地 址 ， 无 论 你 申请 的 是 126 邮 ena con 站 让] 
| 箱 还 是 163 邮箱 ，E-mail 地 址 的 格式 都 是 固定 的 。 
| 本 实例 通过 preg_matchO 正 则 匹配 函数 和 正则 表 
| 达 式 验证 E-mail 地 址 格式 是 否 正确 ， 运 行 结果 如 
| 图 7.7 所 示 。 


| 实现 过 程 


实例 136 ”验证 E-mail 地 址 格式 是 否 正确 


( 实例 位 置 : 配套 资源 \SL\07\136 视频 位 置 : 配套 资源 \SP\07\136 ) 


互联 网 发 展 到 今天 ， 几 乎 所 有 的 Web 爱好 者 
验证 email 地 址 格式 是 否 正 确 


图 7.7 验证 E-mail 地 址 格式 是 否 正 确 
本 实例 的 实现 过 程 与 实例 135 大 同 小 异 。 首 


| 先 ， 创 建 index.php 文件 并 设置 带 有 文本 框 的 表单 ， 当 用 户 单 击 “ 验 证 ”按钮 时 ， 处 理 文 
| 件 会 通过 正则 表达 式 函 数 验证 文本 框 输入 的 信息 并 输出 相关 提示 。 其 代码 如 下 : 


iR$_POST['sub]){ 
Tequire_once("inc.php"); // 包 含 信息 提示 页 
if(preg_match("Aw+([-+.] w+)*@w+([-. wt) w+ w+)*/",trim($_POST['text"]))){// 正 则 表达 


式 验 证 
show_error(" 信 息 提示 "," 格 式 正 确 ","index.php"); /输出 提示 
}else{ 
show_error(" 信 息 提示 "," 格 式 不 正确 ","index.php"); /| 输出 提示 
} 
国 
?> 
技术 要 点 


(1) preg_match0: 进行 正则 表达 式 匹 配 。 用 于 匹配 指定 字符 串 ， 一 般 会 与 让 条 件 语 
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句 协 同 使 用 。 其 语法 如 下 : 
int preg_match ( string pattern, string subject [, array matches] ) | 
函数 功能 : 在 字符 串 subject 中 匹配 表达 式 pattem， 函数 返回 匹配 的 次 数 。 如 果 有 数组 | 
matches， 那 么 每 次 匹配 的 结果 将 被 存储 到 数组 matches 中 。 该 函数 在 匹配 成 功 后 就 停止 继 | 


续 查 找 ， 其 返回 值 是 0 或 1。 


(2) 正则 表达 式 ， 对 E-mail 地 址 进行 验证 。 
Nw+([-+." wt)*@\Ww+([-. wt)*\ w+([-. wt)*/; 

多 学 两 招 : | 

PHP 支持 两 种 正则 表达 式 函数 库 : 一 种 是 正则 表达 式 函 数 库 (POSIX 扩展 )， 另 外 一 | 


种 是 正则 表达 式 函 数 库 (Perl 兼容 )。 在 性 能 上 ， 与 Perl 兼容 相 比 ， 正 则 表达 式 速 度 更 快 | 
| 


实例 137 超 长 文本 的 分 页 输出 


( 实例 位 置 配套 资源 \SL\07\137 视频 位 置 配套 资源 \SP\07\137 ) 


实例 说 明 


在 遍历 文件 的 内 容 时 , 由 于 文件 内 容 很 多 , 最 理想 的 方法 就 是 分 页 输出 文本 中 的 内 容 。 | 
本 例 将 介绍 如 何 将 超 长 文本 分 页 输出 ， 其 运行 效果 如 图 7.8 所 示 。 | 
前 日 购物 空间 


首页 | 会 只 注册 | 公告 | 货物 下 这 | 客服 中 心 


图 7.8 超 长 文本 的 分 页 输出 


[到 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 function.php 文件 ， 编 写 自 定义 函数 msubstr0， 完 成 对 文本 文件 的 截取 操作 。 | 
(2) 创建 index.php 文件 ， 首 先 通过 文件 系统 函数 file_get_contents(0) 读 取 整 个 文件 的 | 
内 容 ， 然 后 调用 自 定义 函数 和 字符 串 函 数 ， 完 成 对 文件 的 截取 操作 ， 并 实现 截取 后 内 容 的 | 
= 人 = Le 
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| [各 
| 
| 分 页 输出 。 其 关键 代码 如 下 : 

| <2php 

| if (isset($ GET['page'])) { // 定 义 初始 变量 的 值 
| Spage=$_ GET['page']; 

| }else{ 


: Spage=1; 


// 变 量 值 为 1 
include("function. php"); // 调 用 自 定义 函数 文件 


?> 


<?php 
// 读 取 超 长 文本 中 的 数据 ， 实 现 超 长 文本 中 数据 的 分 页 显示 
这 $page){ 
$counter=file get_contents("file/file.txt"); // 读 取 文 本 文件 
$length=strlen(unhtml($counter));// 获 取 文 本 文件 的 长 度 , 并 通过 自 定义 函数 去 除 特殊 字符 和 


S$page_count=ceil($length/850); // 对 超 长 文本 进行 分 页 ， 每 页 显示 850 个 字符 
$c=msubstr($counter,0,($page-1)*850); // 计 算 上 一 页 的 字 节 
S$cl=msubstr($counter,0,$page*850); /1/ 计 算 下 一 页 的 字 节 
echo substr($cl,strlen($c),strlen($c1)-strlen($c)); /获取 当前 的 字 节 
1 
?></td> 
<td rowspan="2">&nbsp;</td> 
</tr> 
<tr> 
<td><span class="STYLE3"> 页 次 : <?php echo $page:?> /<?php echo $page_count:?> 页 </span> 
分 页 : 
<?php 
if($page!=1){ 
echo "<a href=index.php?page=1> 首 页 </a>&nbsp;"; 
echo "<a href=index.php?page=".($page-1)."> 上 一 页 </a>&nbsp;"; 


if($page<$page_count){ 
echo "<a href=index.php?page=".($page+1)."> 下 一 页 </a>&nbsp:"; 
echo "<a href=index.php?page=".$page_count."> 尾 页 </a>"; 
} 
| ?> 
| 技术 要 点 
| 完成 超 长 文本 的 分 页 输出 需要 三 方面 的 技术 : 第 一 方面 ， 自 定义 函数 。 通 过 自 定义 函 
| 数 读 取 文本 文件 , 可 以 避免 中 文字 符 串 出 现 乱码 ; 第 二 方面 , 字符 串 函数 。 需 要 通过 stlen0 
| 函数 计算 字符 串 的 长 度 ， 通 过 substr0 函 数 对 字符 串 进行 截取 ， 第 三 方面 ， 文 件 系 统 函数 。 
| 通过 file_get_contents() 函 数 读 取 文 本 文件 中 的 数据 。 
| 自 定义 函数 msubstr0 的 语法 如 下 : 
| function msubstr($str,$start,$len){ //$str 指 的 是 字符 串 ，$start 指 的 是 字符 串 的 起 始 位 置 , $len 指 的 


| 是 长 度 
| S$tmpstr="": 
S$strlen=Sstart+$len;// 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
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for($i=0;$i<$strlen: $i++){ // 通 过 for 循环 语句 ， 循 环 读 取 字 符 串 
if(ord(substr($str,$i,1))>0xa0){// 如 果 字 符 串 中 首 个 字 节 的 ASCII 序数 值 大 于 0xa0， 则 表示 


为 汉字 
$tmpstr.=substr($str,$i,2); ” // 每 次 取出 两 位 字符 赋 给 变量 $tmpsttr， 即 等 于 一 个 汉字 
Sitt; // 变 量 自 加 1 
jelsef // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
S$tmpstr.=substr($str,$1,1); 
} 
} 
return $tmpstr; /输出 字符 串 | 
; | 
多 学 两 招 : 


如 果 文 字 信息 的 数量 过 多 ， 最 好 使 用 分 页 来 显示 。 在 每 一 页 中 显示 指定 数量 的 文字 信 
息 ， 如 果 超过 指定 数量 就 在 下 一 页 中 显示 。 


实例 138 统一 上 传 文件 名 称 的 大 小 写 | 


( 实例 位 置 : 配套 资源 \SL\07\138 ) 


实例 说 明 


统一 上 传 文件 名 称 的 大 小 写 是 十 分 必要 的 。 例 
如 ， 人 imgjpg 和 Imsg jpg, 如 果 文 件 名 关键 字 : RTX Files\P1020094wjpg [CN 蜗 .…][ 上 和 传 ] 
称 未 经 大 小 写 统一 ， 上 传 时 可 能 就 不 全 出现 复 放 提交 ooo 
示 。 本 实例 oe 串 函 数 strtoupper()、strtolower() - | 
实现 统一 上 传 文件 名 称 的 大 小 写 ， 运 行 结果 如 图 7.9 ”图 79 统一 上 传 文件 名 称 的 大 小 写 
所 示 。 | 
实现 过 程 | 
具体 步骤 如 下 : 
(1) 创建 PHP 脚本 文件 。 当 单 击 “ 上 传 ” 按 钮 时 ， 分 别 利用 转换 小 写 和 大 写 的 函数 | 


strtolower()、strtoupper0) 将 接收 到 的 文本 框 的 信息 进行 对 应 的 大 小 写 转换 ， 并 输出 转换 结 
果 。 其 代码 如 下 : 


<?php | 
这 $_ POST[sub]){ // 通 过 POST 方式 传 参 | 
$a = strtoupper($_POST[text]): /转换 为 大 写 | 
echo "文件 名 称 自动 转换 为 大 写 : ".$a."<br>": 1/ 输出 | 
$b = strtolower($_ POST[text): /转换 为 小 写 | 
echo "文件 名 称 自动 转换 为 小 写 : ".$b: // 输 出 | 
?> 


(2) 将 该 文件 存储 于 \MR\02\091\ 文 件 夹 下 ， 并 命名 为 index.php。 运 行 结 果 如 图 7.9 


245 
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E 
| 所 示 。 
| 技术 要 点 
会 内 | 实现 字符 串 的 大 小 写 转 换 ， 主 要 通过 sttolower0 和 strtoupper0 函 数 。 


| (1) strtolower(): 转换 为 小 写 。 
string strtolower ( string str ) 
(2) strtoupper0: 转换 为 大 写 。 
string strtoupper ( string string ) 


参数 string 为 需要 转换 的 字符 串 。 


实例 139 货币 数据 的 格式 化 输出 


( 实例 位 置 : 配套 资源 \SL\07\139 ) 


实例 说 明 


货币 数据 不 同 于 整 型 数据 ,货币 数据 是 存在 一 定 。 ”家 一 一 


| 格式 的 。 本 实例 通过 函数 number_format0 实 现货 币 数 
| 据 的 格式 化 输出 。 运 行 结果 如 图 7.10 所 示 。 
| 实现 过 程 


13,587.00 


图 7.10 货币 数据 的 格式 化 输出 


| 实现 此 格式 化 输出 的 过 程 相 当 简 单 。 创 建 名 称 为 “index.php” 的 PHP 脚本 文件 ， 当 用 
| 户 输入 需要 格式 化 的 数字 并 单 击 “ 格 式 化 ”按钮 时 ， 程 序 自动 将 文本 框 中 的 信息 格式 化 。 
| 代码 如 下 ; 


<?php 
这 !empty($_POST["sub"])){ // 通 过 POST 方式 传递 参数 
echo number format($ POST["text"],2); /格式 化 数字 
?> 
| 脚下 留神 : 


| 格式 化 函数 number format() 存 在 两 种 结构 ， 这 里 只 应 用 保留 小 数 点 后 位 数 的 结构 。 另 
| 一 种 结构 和 参数 请 参看 技术 要 点 中 的 内 容 。 
| 技术 要 点 

货币 数据 的 格式 化 输出 通过 函数 number format0 实 现 。 其 语法 说 明 如 下 : 


string number format ( float number , int decimals) 
string number format ( float number int decimals, string dec_point string thousands_sep) 


number_format() 函 数 返 回 参 数 number 格式 化 后 的 字符 串 , 该 函数 可 以 有 1 个 、2 个 或 
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是 4 个 参数 ， 但 不 能 是 3 个 参数 。 如 果 只 有 1 个 参数 mumber，number 格式 化 后 会 合 去 小 | 
数 点 后 的 值 ， 且 每 陋 3 位 〈 千 位 ) 就 会 以 逗号 〔, ) 来 隔 开 ， 如 果 有 2 个 参数 ，number 格 | 
式 化 后 会 到 小 数 点 第 decimals 位 , 且 每 隔 3 位 就 会 以 去 号 来 隔 开 ; 如 果 有 4 个 参数 ,number | 
格式 化 后 会 到 小 数 点 第 decimals 位 ，dec_point 用 来 替代 小 数 点 〈.)，thousands _sep 用 来 替 | 
代 每 3 位 隔 开 的 逗号 (，)。 


多 学 两 招 : | 
开发 电子 商务 类 网 站 时 ， 函数 number format0 出 现 的 频率 是 百分之百 的 ， 所 以 掌握 此 | 
函数 是 十 分 必要 的 。 | 


实例 140 统一 英文 注册 用 户 首 字母 大 小 写 


( 实例 位 置 : 配套 资源 \SL\07\140 ) 


实例 说 明 | 

网 站 的 国际 化 已 经 不 是 一 个 炙手可热 的 话题 ， 但 是 由 于 地 区 差异 ， 在 使 用 英文 填写 注 | 
册 信息 时 首 字母 大 小 写 得 不 到 统一 。 本 实例 利用 函数 ucfirst0 实 现 英 文 注册 用 户 首 字 母 统 | 
一 为 大 写 ， 运 行 结 果 如 图 7.11 所 示 。 


用 户 名 中 hello PEP 
提交 


首 字 母 统一 流 大 写 fHello PHP 
图 7.11 统一 英文 注册 用 户 首 字母 的 大 小 写 


实现 过 程 
创建 PHP 脚本 文件 。 当 用 户 单 击 “ 提 交 ” 按 钮 时 ， 首 先 利用 POST 方法 获取 从 文本 框 
传递 进来 的 数据 。 然 后 将 获取 的 数据 经 ucfirst 函数 转换 为 首 字母 大 写 ， 最 后 输出 经 转换 后 | 
的 数据 。 具 体 代码 如 下 : | 
<2?php 
JIRWIempty($_POST["sub"])){ // 通 过 POST 方式 传 参 
$a=$_ POST["text"]: /接收 参数 
echo " 首 字 母 统一 为 大 写 :"; 
echo ucfirst($a); /| 转换 单词 首 字母 
} 
?> 
技术 要 点 


在 PHP 开发 中 定义 首 字 母 大 写 的 方法 有 很 多 种 ， 但 是 所 有 的 方法 都 没有 PHP 预定 义 
函数 ucfirst 简单 。ucfirst 的 语法 如 下 : | 
string ucfirst ( string str ); 
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参数 string str 为 定义 字符 串 。 


多 学 两 招 : 

要 实现 字符 串 首 字母 大 小 写 转换 还 可 以 通过 转 码 来 完成 .首先 利用 通 数 substr() 提 取出 
字符 串 的 首 字母 ， 然 后 利用 函数 ord() 获 取 该 字母 的 ASCII 码 , 再 根据 大 小 写字 母 之 间 相 差 
32 来 实现 大 小 写字 母 之 间 的 ASCII 码 转换 ， 最 后 利用 函数 chr() 将 转变 后 的 ASCII 码 转 变 
为 字母 即 可 。 


实例 141 解决 用 substr(0) 函 数 对 中 文字 符 串 截取 时 乱码 


( 实例 位 置 : 配套 资源 \SL\07141 ) 


实例 说 明 

substr() 函 数 是 按 字 节 进 行 截取 字符 串 的 。 在 截取 中 文字 符 串 时 ， 由 于 一 个 汉字 由 两 个 
字符 组 成 ， 如 果 只 截取 1 个 字符 就 会 出 现 乱 码 。 本 实例 使 用 自 定义 函数 解决 对 中 文字 符 串 
截取 时 的 乱码 问题 ， 运 行 结果 如 图 7.12 所 示 。 


吉林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 
从 锁 ! 。” 字 开 始 埠 取 ,截取 [1 ”个 字 。 
吉林 省 明日 科技 有 限 公司 


图 7.12 解决 用 substr0 函 数 对 中 文字 符 串 截取 时 的 乱码 问题 
实现 过 程 
创建 index.php 文件 ， 定 义 msubstr0 函 数 ， 对 中 文字 符 串 进行 截取 。 创 建 form 表单 ， 
提交 字符 串 截 取 的 开始 位 置 和 长 度 ， 然 后 调用 msubstr0 函 数 对 字符 串 进行 截取 ， 并 输出 截 
取 结 果 。 具 体 代码 如 下 : 
<?php 


function msubstr($str, $start, $len) { //$str 指 的 是 字符 串 ，$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 
的 是 长 度 


if($len%2—0){ // 判 断 输 入 的 数字 是 否 为 偶数 
Slen=$len*3; // 根 据 输入 的 数字 获取 汉字 所 占 位 数 
}else{ 
Slen=($len+1)*3-2:; /根据 输入 的 数字 获取 汉字 所 占 位 数 
} 
$strlen = $start + $len; // 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i= 0; $i< $strlen; $i++) { // 通 过 for 循环 语句 ,循环 读 取 字符 串 


让 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCI 序 数值 大 于 0xa0， 
则 表示 为 汉字 
$tmpstr .= substr ( $str, $i, 2 ):// 每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 
$i++; /变量 自 加 1 
}else { // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
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S$tmpstr .= substr ( $str, $i, 1 ): 


D | 
ey Stmpstr: // 输 出 字符 串 
ry 明 日 科技 有 限 公 司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 "; = 
0 
?> | 


本 实例 以 汉字 为 例 ， 在 应 用 自 定义 函数 时 ， 如 果 不 将 传 入 截取 字符 串 的 值 以 原 数值 3 | 
倍 给 出 ， 可 能 会 导致 获取 的 汉字 字符 数量 为 原来 的 一 半 ， 故 这 里 必须 将 传 入 值 以 原 数 3 倍 | 
作为 参数 给 出 。 


技术 要 点 
自 定义 函数 msubstr0 的 语法 如 下 : 
function msubstr($str, $start, $len) { //$str 指 的 是 字符 串 ，$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 
的 是 长 度 
$strlen = $start + $len; /用 $strlen 存储 字符 串 的 总 长 度 ( 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 ) 
for($i=0; $i1< $strlen; $i++) { /通过 for 循环 语句 ， 循 环 读 取 字符 串 
让 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCI 序 数值 大 于 0xa0， 
则 表示 为 汉字 
$tmpstr .= substr ( $str, $i, 2 ); /每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 
$i++; /变量 自 加 1 
} else { // 如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
S$tmpstr .= substr ( $str, $i, 1 ); 
h 
} 
Teturn $tmpstr: /输出 字符 串 
} 


参数 $str 是 指定 被 截取 的 字符 串 ， 参 数 $strart 是 截取 的 开始 位 置 ， 参 数 Slen 是 截取 的 
长 度 ; 返回 值 Stmpstr 是 截取 后 的 字符 串 。 


多 学 两 招 : | 
使 用 msubstr0 截 取 中 文 最 好 先 定 义 算法 ， 以 免 截 取 半 个 中 文字 而 出 现 乱 码 。 | 


实例 142 ”将 元 素 中 指定 位 置 的 索引 替换 | 

( 实例 位 置 : 配套 资源 \SL\07\142 ) | 

实例 说 明 
创建 数组 时 ， 有 时 会 由 于 疏忽 将 元 素 内 容 书写 错误 ， 更 改 错误 的 元 素 内 容 可 以 通过 数 
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| 组 键 值 来 完成 。 本 实例 通过 数组 下 标 〈 键 值 ) 将 数组 中 指定 索引 位 置 的 元 素 蔡 换 ， 运 行 结 


| 果 如 图 7.13 所 示 。 
[Anay( 思 -> TD 二 宇明 加 二 > asd 加 =- asd123) 
指定 索引 元 吉 关 后 的 妆 旨 :Array ( [=、 工 国王 、 葡 组 四 =、 过 济 国 =、 
asd173 ) 
刍 们 1 的 元 来 闫 生 更 次 
图 7.13 将 数组 中 指定 索引 位 置 的 元 素 替 换 
| 实现 过 程 
创建 index.php 文件 ， 定 义 数 组 变量 并 通过 数组 下 标 输出 元 素 。 其 代码 如 下 : 
<2php 
echo " 原 数 组 元 素 :"; 
$a = array(1',' 精 细 ','asd','asd123"); /定义 数组 
print r($a); 1/ 打印 数组 
echo "<br> 指 定 索 引 元 素 替换 后 的 数组 :"; 
$a[2] = ' 经 济 '; // 根 据 数 组 下 标 更 改元 素 
Print r($a); // 打 印 更 改 后 的 数组 
echo "<br> 键 值 2 的 元 素 发 生 更 改 "; 
| ?> 
| 技术 要 点 


PHP 数字 索引 由 数字 组 成 , 下 标 从 0 开始 , 数值 索引 一 般 表 示 数 组 元 素 在 数组 中 的 位 置 ， 


数字 索引 数组 默认 索引 值 从 数字 0 开始 , 不 需要 特别 指定 , PHP 会 自动 为 索引 数组 的 键 名 赋 


一 个 整数 值 ， 然 后 从 这 个 值 开始 自动 增 量 。 当 然 ， 也 可 以 指定 从 某 个 位 置 开始 保存 数据 。 


| 多 学 两 招 


当 使 用 数组 名 称 [ 键 值 ] 这 样 的 格式 时 ， 要 注意 数组 键 值 是 从 0 开始 的 ， 所 以 本 实例 中 


更 政 键 值 为 2 的 元 素 其 实 是 数组 中 的 第 三 个 元 素 。 


实例 143 统计 数组 元 素 的 个 数 


( 实例 位 置 : 配套 资源 \SL\07\143 ) 


实例 说 明 


数组 下 标 默认 是 以 0 为 开始 键 值 的 整 型 数据 。 如 果 我 们 想 取得 数组 元 素 的 个 数 ， 就 要 
使 用 countO 函 数 。 本 实例 通过 count0 函 数 统计 数组 元 素 的 个 数 ， 运 行 结果 如 图 7.14 所 示 。 


数组 中 存在 元 素 4 个 
图 7.14 统计 数组 元 素 的 个 数 
实现 过 程 


创建 index.php 文件 。 首 先 定义 数组 变量 并 为 此 变量 赋值 ， 然 后 利用 count0 函 数 输出 
数组 元 素 的 个 数 。 其 代码 如 下 : 


“220* 


第 7 章 字符 率 高 级 处 理 


<?php 
$a 二 array(1',' 精 细 ','asd','asd123"); /声明 数组 
echo "数组 中 存在 元 素 "count($a)." 个 ": // 计 算数 组 元 素 个 数 
?> 
在 PHP 中， 应 用 count0 函 数 可 以 对 数组 中 的 元 素 的 个 数 进行 统计 。 其 语法 如 下 : 
int count ( mixed array [, int mode]) 
参数 说 明 : 
回 array: 必 选 参数 ， 指 定 被 统计 的 数组 。 | 
回 mode: 可 选 参数 ，COUNT RECURSIVE (或 1 ) ， 如 选中 此 参数 ， 本 函数 将 递 | 
归 地 对 数组 计数 ， 对 计算 多 维 数组 的 所 有 单元 尤其 有 用 ， 此 参数 的 默认 值 为 0。 | 


如 果 count() 函 数 的 操作 对 象 是 “NULL”， 那 么 返回 结果 为 0。count(O) 函 数 对 没有 初始 | 
化 的 变量 返回 0， 但 对 于 空 的 数组 也 会 返回 0。 如 果 要 判断 变量 是 否 初始 化 ， 则 可 以 应 用 | 
issetO) 函 数 。countO 函 数 不 能 识别 无 限 递归 。 | 


实例 144 去 除数 组 中 的 重复 元 素 


( 实例 位 置 : 配套 资源 \SL\07\144 ) 


实例 说 明 | 

在 数组 中 ， 键 值 是 唯一 的 ， 但 是 元 素 的 值 是 可 以 重复 的 。 想 要 删除 数组 元 素 中 重复 的 
值 ， 可 以 使 用 函数 array_unique0。 本 实例 是 通过 数组 函数 array_unique0 去 除数 组 中 的 重 | 
复元 素 值 ， 运 行 结果 如 图 7.15 所 示 。 | 
厌 数 组 先 来 为 Ariy ( [0] => a [1] => B27 和 $3 站 -> d 国 -=>a [9 fi 


=>a[l] =Sh18)=>a) 
去 除 重复 项 后 的 数组 为 : Array ( [0] => a [1]=> 5B[3] => d [5 =>f[7]=>hy) 


图 7.15 去 除数 组 中 的 重复 元 素 


实现 过 程 


创建 index.php 文件 。 首 先 创建 数组 变量 $a 并 为 $a 赋值 ， 然 后 利用 array_uniqueO 去 除 
数组 中 的 重复 元 素 值 ， 最 后 打印 数组 。 其 代码 如 下 : | 


<?php 

$a = array('a','b’,'a','d','a','f,'a',h','a'); // 定 义 数 组 

echo " 原 数 组 元 素 为 :"; 

print T($a): /打印 数组 

echo "<br> 去 除 重复 项 后 的 数组 为 : ": 

print r(array_ unique($a)): // 输 出 去 除 重复 项 的 数组 
2> 
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TD 
技术 要 点 
在 PHP 中， 可 以 通过 array_unique() 函 数 去 除数 组 中 的 重复 元 素 。 其 语法 如 下 : 
全 | array array_Unique ( array array); 
参数 array 为 指定 参数 的 数组 ， 其 返回 值 为 一 个 没有 重复 元 素 的 新 数组 。 


| 多 学 两 招 ; 
| 用 strlen0) 函 数 获取 字符 囊 长 度 时 ， 如 果 字 符 串 中 存在 空格 ， 则 空格 也 会 被 计算 在 内 。 


实例 145 判断 字符 串 中 是 否 存 在 指定 子囊 


( 实例 位 置 : 配套 资源 \SL\07\145 ) 


”实例 说 明 
”判断 一 个 字符 串 中 是 否 合 有 另 一 个 字符 吕方 法 。。 i 

| 有 很 多 ， 例 如 ， 正 则 表达 式 等 。 本 实例 通过 stisr0 Eo 了 TT 
| 函数 判断 字符 串 中 是 否 存在 指定 子 串 ， 运 行 结果 如 eranere 

| 图 7.16 所 示 。 
| 实现 过 程 


| 创建 index.php 文件 ， 定 义 字符 串 变 量 ， 将 该 变 
| 量 与 通过 POST 方式 传递 进来 的 数据 利用 stristr0 函 数 进行 比较 并 输出 结果 。 有 具体 代码 如 下 : 


图 7.16 字符 串 中 不 存在 子 串 


<?php 

$a = "Hello World !1": // 定 义 字符 串 
echo $a: // 输 出 字符 串 
echo "<form action= "method='post>": /输出 表单 


echo "<input type='text name='text value=' 输 入 文本 内 容 >"; 
echo "<input type='submit name='sub' value=' 提 交 >"; 
echo "</form>": 
if(!lempty($_POST["sub"]){ // 通 过 POST 方式 传递 参数 
if(stristr($a, $_ POST["text"]) (= ""){ // 判 断 是 否 存 在 子 串 
echo "<script>alert(' 文 本 存在 指定 子 串 "):</script>"; // 提 示 
}else{ 
echo "<script>alert(' 文 本 不 存在 指定 子 串 ');</script>"， // 提 示 


| ?> 
| 技术 要 点 


通过 stristr0 函 数 可 以 判断 一 个 字符 串 是 否 为 另 一 个 字符 串 的 子 串 。 其 语法 如 下 : 
string stristr ( string haystack, string needle ): 
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获取 指定 字符 串 (A) 在 另 一 个 字符 串 (B) 中 首次 出 现 的 位 置 到 (B) 字符 串 末 尾 的 
所 有 字符 串 。 参 数 haystack 指定 查找 的 字符 串 ， 参 数 needle 指定 查找 的 对 象 。 | 
该 函数 如 果 执 行 成 功 ， 则 返回 剩余 的 字符 串 ， 否 则 将 返回 false。 


多 学 两 招 : 中 ~ 
本 函数 还 可 以 作为 分 害 函 数 的 一 部 分 ， 从 符合 条 件 的 字符 囊 开 始 截 取 ， 一 直 取 到 文件 国光 


末尾 。 该 函数 不 区 分 大 小 写 , 如 果 要 在 区 分 字母 大 小 写 的 情况 下 进行 搜索 , 可 以 应 用 strstr() | 
最 数 。 | 


实例 146 合并 数组 


( 实例 位 置 : 配套 资源 \SL\07\146 ) 


实例 说 明 
数组 与 数组 之 间 是 彼此 独立 的 ， 但 是 两 个 数 Ci 


数组 1 Array( ple >》 PEFP 范 例 宝 热 [=oit]j => 明日 


组 可 以 合并 到 一 起 成 为 一 个 新 数组 。 本 实例 通过 Tee er 


数组 函数 array_merge()5 实现 合并 数组 ， 运 行 结果 i pl ee ee 0 ] =>JAV4 纺 稳 上 路 
如 图 7.17 所 示 。 FE Ns es ep 


日 科技 [fi 
程 [3] =、 Ch 病程 [47 =， Wk ET 扩 各 


实现 过 程 

创建 index.php 文件 , 定义 两 个 数组 变量 并 为 | 
数组 变量 赋值 。 当 用 户 单 击 “ 合 并 数组 ”按钮 时 ， 利 用 函数 array_merge 合并 数组 ， 并 打 | 
印 合并 后 的 数组 。 其 代码 如 下 : | 


<2php 

$array =array(" 编 程 "=>"PHP 实例 宝典 ","soft"=>" 明 日 科技 ","456"=>"mingri"); /定义 数组 1 

echo "数组 1: "; 

print r($array); /打印 数组 

echo "<br><br>"; 

$arr = array("PHP 编程 ","JAVA 编程 ","C# 编 程 ","ASPNET 编程 ); /定义 数组 2 

echo" 数 组 2: "; 

Print_r($arr); 1/ 打印 数组 

echo "<br><br>"; 

if(empty($_POST["sub"]){ // 通 过 POST 方式 传递 参数 

echo "合并 后 的 数组 "; 
print_r(array_merge($array, $arr)): 1/ 打印 合并 后 的 数组 


图 7.17 合并 数组 


} 


?> 
数组 的 合并 是 应 用 了 array_merge 函数 。 其 语法 如 下 : 


atTay array_merge ( array arrayl [, array array2 [, array .…]] ); 
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参数 说 明 : 
回 array arrayl: 数组 1。 
回 array array2: 数组 2。 


A 


array_merge() 将 一 个 或 多 个 数组 的 单元 合并 起 来 , 一 个 数组 中 的 值 附加 在 前 一 个 数组 
| 的 后 面 。 返 回 作为 结果 的 数组 。 如 果 输 入 的 数组 中 有 相同 的 字符 串 键 名 ， 则 该 键 名 后 面 的 
| 值 将 覆盖 前 前 一 个 值 。 然 而 ， 如 果 数 组 包含 数字 键 名 ， 后 面 的 值 将 不 会 覆盖 原来 的 值 ， 而 是 附 

| 加 到 后 面 如 果 只 给 了 一 个 数组 并 且 该 数组 是 数字 索引 的 ， 则 键 名 会 以 连续 方式 重新 索引 。 


实例 147 拆 分 数组 


( 实例 位 置 : 配套 资源 \SL\07\147 ) 


存在 数组 的 合并 函数 当然 也 就 存在 数组 的 拆 分 函数 。 本 实例 通过 函数 array_chunkO 实 


| 现 数组 的 拆 分 ， 运 行 结果 如 图 7.18 所 示 。 


拆 分 部 组 


数组 。Arnay gd [0] => 时 [1] 二 JAVA 编 程 /[2] 
区 O08 编程 [3] 3VASP.NET 编 程 ) 


所 分 后 的 数组 ， Array)(30]PP Array ( [0] => BF 锦 积 
= Bk 且 ] = Mray ( [0] = ?om 办 Ny 


| 图 7.18 拆 分 数组 
| 实现 过 程 


创建 PHP 脚本 文件 ， 定 义 数组 变量 并 为 此 数组 变量 赋值 。 当 用 户 单 击 “ 拆 分 数组 ” 按 


| 钮 时 ， 打 印 被 拆 分 后 的 数组 。 其 代码 如 下 
| <?php 


$arr = array("PHP 编程 ","JAVA 编程 ","C# 编 程 ","ASPNET 编程 "); 


echo" 原 数组 :"; 
Print_r($arr); 
echo "<br><br>"; 
echo " 拆 分 后 的 数组 :"; 
iflempty($_POST["sub"])){ 
print_r(array_chunk($arr,2))."<br>"; 
} 


?> 


| 技术 要 点 


/定义 数组 
/打印 数组 


// 通 过 POST 方式 传递 参数 
// 拆 分 数组 


array_chunkO 函 数 可 以 将 一 个 数组 分 割 成 多 个 ， 原 理 就 是 将 原 有 数据 根据 传递 的 参数 


| 不 同 分 割 成 多 个 二 维 数组 。 其 语法 如 下 : 
array array_chunk ( array input, int size [, bool preserve_keys] ); 
J 0 
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参数 说 明 : 
回 array input: 源 数 组 。 
回 int size: 分 割 成 指定 数量 的 数组 。 


多 学 两 招 : 傅 -] 
在 用 array chunkO) 函 数 拆 分 的 数组 中 ， 最 后 一 个 数组 的 单元 数目 可 能 会 少 几 个 。 


实例 148 将 时 间 和 日 期 转换 为 时 间 截 


( 实例 位 置 : 配套 资源 \SL\07\148 ) 


实例 说 明 
将 日 期 转换 为 时 间 戳 是 将 时 间 进 行 数学 运算 的 De 
重要 手段 。 本 实例 通过 time0 函 数 实现 将 日 期 和 时 间 转换 成 时 间 稚 为 ;N1277518576 
转换 为 时 间 戳 ， 运 行 结 果 如 图 7.19 所 示 。 图 719 将 日 期 和 时 间 转 换 为 时 间 惟 
实现 过 程 
创建 mdex.php 文件 。 首 先 设置 PHP 的 时 区 为 中 国 上 海 ， 然 后 利用 time0 函 数 获取 当 


前 的 时 间 戳 ， 并 通过 echo 语句 输出 时 间 戳 。 其 代码 如 下 : 


<2php 

date_default timezone set("Asia/ShangHai"); /设置 时 区 
echo "当前 时 间 : "date(CY-m-d His): // 取 得 当前 时 间 
echo "<br> 转 换 成 时 间 戳 为 : "time0: /转换 为 时 间 戳 
?> 


获取 系统 UNIX 时 间 惟 的 方法 有 很 多 种 ，time0 函 数 是 比较 常用 的 一 种 方法 ， 其 语法 
如 下 : | 
int time ( void ); 
该 函数 没有 参数 ， 返 回 值 为 UNIX 时 间 戳 的 整数 值 。 
多 学 两 招 : 


将 当前 日 期 和 时 间 转 换 为 时 间 蕉 的 方法 有 很 多 种 ， 下 面 笔者 就 通过 strtotime0 函 数 实 | 
现 上 例 功 能 。 代 码 如 下 : | 


<?php 
date_default timezone set("Asia/ShangHai"); /设置 时 区 
echo "当前 时 间 : ".date('Y-m-d H:is); /设置 当前 日 期 和 时 间 
echo "转换 时 间 蕉 为 : "strtotime("now"); /转换 为 时 间 戳 

> 


ss a 
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实例 149 网 页 阅 钟 


( 实例 位 置 : 配套 资源 \SL\07\149 ) 


”实例 说 明 


| 六 名 是 我 们 生活 中 经 常 使 用 的 一 个 小 工具 , 它 会 二 计生 
| 在 指定 时 间 叫 你 起 床 。 在 Web 程序 中 ， 我 们 也 可 以 Ea MA CZ 
| 应 用 这 个 原理 ， 开 发 一 个 “网 页 闹钟 ” 提示 用 户 在 i 
| 指定 的 时 间或 者 时 间 段 内 要 做 什么 工作 。 本 实例 通过 ce 
| strtotimeO 函 数 实现 网 页 冰 钟 程序 , 运行 结果 如 图 7.20 
| 所 示 。 图 7.20 网 页 六 钟 
| 实现 过 程 
有 具体 步骤 如 下 : 


(1) 创建 index.php 文件 。 首 先 定义 PHP 时 区 为 中 国 上 海 ， 然 后 编写 form 表单 ， 并 
通过 mktimeO 函 数 实现 获取 当前 的 时 间 戳 。 其 代码 如 下 : 


<2php 

echo "<table border='1' bordercolor='#FF0000' cellspacing="0' align='center’><tr><td>"; // 输 出 表格 
echo "<h2 style='color:#0033FF> 曾 钟 程序 </h2>"; // 输 出 标题 
date_default_timezone set("Asia/ShangHai"); /设置 时 区 

echo "<h6 style='color:red'> 今 天 是 ".date("Y-m-d H:i:s")."</h6>"; // 输 出 当前 时 间 

echo "<form action=" method='post>": // 输 出 表单 


echo "<input type='text name='textl' size='2> 年 <input type='text name='text2' size=' 2 > 月 " 
echo "<input type='text name='text3' size= 2> 日 <br><input type='text name='text4' size=' 2 > 时"; 
echo "<input type='text name='text5' size='2 > 分 <input type='text name='text6' size='2> 秒 <br>"; 
echo "<input type='submit name='sub' value=' 定 时 '>"; 

echo "</form>"; 


$a=$_POST["textl"]: // 取 得 文本 框 内 容 
| $b=$_POST["text2"]; // 取 得 文本 框 内 容 
| $c=$_POST["text3"]: // 取 得 文本 框 内 容 
| $d=$_ POST["text4"]; // 取 得 文本 框 内 容 
| $e=$_POST["text5"]: // 取 得 文本 框 内 容 
| S$f= $_POST["text6"]: /取得 文本 框 内 容 
| $time = date(mktime($d, $e, Sf $b, $c, $a)): /获取 时 间 戳 
| $_SESSION['time'] = $time; /保存 在 SESSION 中 
| ifisset($_POST["sub"])){ /通过 POST 传递 参数 
| echo"<script>window.location.href="in.php':</script>"; // 跳 转 
| } 
| echo "</td></></table>"; 
| ?> 


| (2) 创建 in.php 文件 ， 应 用 SESSION 实现 特定 日 期 的 判定 。 如 果 当 前 日 期 已 到 指定 
| 的 日 期 ， 则 给 出 提示 ， 和 否则 输出 “距离 XXX 的 生日 还 有 XX 天 ”字样 。 其 代码 如 下 : 


“226' 


<?php 
date_default timezone set("Asia/ShangHai"); // 设 置 时 区 
Stime_1 = time(); /取得 当前 时 间 戳 
这 $_ SESSION[Ytime]< $time 1){ // 判 断 条 件 
echo "<script>alert( 时 间 一 去 不 复 返 ');location.href='index.php'</script>"; // 输 出 提示 
}else{ 
这 $_SESSION[ime] 一 Stime 1){ // 漳 断 条 件 
echo "<script>alert( 今 天 是 XXX 生日 );</script>"; /| 输出 提示 
jelse{ // 输 出 提示 
echo "距离 XXX 的 生日 还 有 ".ceil((($_SESSION['time']-$time_1)/(3600*24)))." 天 "; 
} 
} 
?> 


PHP 中 应 用 mktime0 函 数 将 一 个 时 间 转 换 成 UNIX 的 时 间 共 值 。mktime0 函 数 根据 给 | 


出 的 参数 返回 UNIX 时 间 戳 。 时 间 戳 是 一 个 长 整数 , 包含 从 UNIX 纪元 到 给 定时 间 的 秒 数 。 
mktime() 函 数 的 语法 如 下 : 
int mktime ( [int hour [, int minute [, int second [, int month [, int day [, int year [, int is_dst]]]]]]] ); 
mktimeO 函 数 的 参数 说 明 如 表 7.1 所 示 。 
表 7.1 mktime() 函 数 的 参数 说 明 


参数 说 了 明 
hour 小 时 数 
minute 分 钟 数 
second 秒 数 〈 一 分 钟 之 内 ) 
month 月 份 数 
day 天 数 
年 份 数 ， 可 以 是 两 位 或 四 位 数字 ，0 一 69 对 应 于 2000 一 2069，70 一 100 对 应 于 
1970~2000 
参数 is_dst 在 夏令 时 可 以 设 为 |， 如 果 不 是 则 设 为 0， 如 果 不 确定 是 否 为 夏令 
a 时 则 设 为 -1 (默认 值 ) 
多 学 两 招 : 


PHP 为 UNIX 时 间 鹤 的 处 理 提供 各 种 函数 。 到 目前 的 PHP 版 本 为 止 ， 由 于 任何 已 知 
Windows 版 本 以 及 一 些 其 他 系统 均 不 支持 负 的 时 间 鹤 ， 因 此 在 Windows 中 无 法 表示 1970 
年 1 月 1 日 之 前 的 时 间 。 因 为 目前 UNIX 时 间 戳 是 以 32 位 二 进 制 表 示 的 ，32 位 二 进 制 数 
值 范围 为 ( -2147483648~+2147483647 ), 因此 , 目前 UNIX 时 间 蕉 可 表示 的 最 大 时 间 为 2038 
年 1 月 19 日 3 点 14 分 7 秒 ， 该 时 刻 时 间 戳 为 2147483647， 对 于 该 时 刻 之 后 的 时 间 ， 需 要 
扩展 表示 UNIX 时 间 戳 的 二 进 制 位 数 。 
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PHP 数组 应 用 


本 章 读者 可 以 学 到 如 下 实例 : 

WI 实例 150 查看 最 便宜 的 图 书 

WI 实例 151 随机 抽取 图 书 

MH ”实例 152 车 牌 摇号 

WI 实例 153 获取 上 传 文件 的 数据 

MH 实例 154 $_FILES[] 全 局 数组 在 文件 上 传 中 的 应 用 
MH ”实例 155 图 书信 息 逆 向 输出 

WI 实例 156 统计 图 书 的 数量 

WI 实例 157 获取 图 书馆 中 最 受 欢迎 的 3 本 图 书 
如 实例 158 生成 在 线 考 试题 

WI 实例 159 向 购物 车 中 添加 商品 

MH 实例 160 查看 购物 车 

WI 实例 161 从 购物 车 中 移 去 指定 商品 

MH ”实例 162 修改 商品 购买 数量 

WI 实例 163 清空 购物 车 

MH ”实例 164 收银 台 结 账 


世 
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实例 150 查看 最 便宜 的 图 书 


( 实例 位 置 : 配套 资源 \SL\08\150 ) 


实例 说 明 
在 图 书 管理 系统 中 ， 将 图 书 的 名 称 和 价格 存放 在 数组 
中 ,并 按 价格 由 高 到 低 的 顺序 排列 。 当 需要 查找 最 便宜 的 图 
书 时 ， 单 击 “ 查 看 最 便宜 的 图 书 ” 按 钮 ， 应 用 amray popO 
函数 弹出 数组 中 末尾 的 单元 ， 运 行 结果 如 图 8.1 所 示 。 
实现 过 程 | 
具体 步骤 如 下 : 图 8.1 检索 最 便宜 的 图 书 
(1) 创建 index.php 文件 ， 并 设计 页 面 表单 元 素 。 
(2) 编写 实现 代码 ， 具 体内 容 如 下 : 


<?php 
Sarray 一 amay("79"->"jsp 图 书 ""69"=>"asp 图 书 ","59"=>"php 图 书 "; 。 /声明 一 个 数组 garray 
if($_POST){ // 通 过 $_POST[] 方 式 传递 表单 的 数组 $array 


$a = array_pop($array); 
echo "最 便宜 的 图 书 是 ， $a"; 
} 


?> 
技术 要 点 
本 实例 主要 使 用 array_pop0 函 数 输出 并 返回 数组 的 最 后 一 个 单元 ， 然后 数组 的 长度 | 
减 一 ， 如 果 数 组 为 空 ( 或 者 不 是 数组 ) 则 返回 null。 该 函数 的 语法 格式 如 下 : | 
mixed array_pop ( array array) 


参数 array 为 输入 的 数组 。 


实例 131 随机 抽取 图 书 


( 实例 位 置 配套 资源 \SL\08\151 ) 


实例 说 明 

本 实例 应 用 array_rand0 函 数 从 图 书馆 的 
技术 类 图 书 中 随机 抽取 3 本 书 做 推荐 图 书 ， 
运行 结果 如 图 8.2 所 示 。 ene 


thr 基础 实例 


hz 程序 设计 


实现 过 程 Fhp 共 型 过 例 


第 机 油 肥 三 本 书 


具体 步 又 如 下 : 
(1) 创建 index.php 文件 ， 并 设计 表单 图 8.2 随机 抽取 图 书 | 
“229 。 


| 页 面 
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| (2) aray_rand0 函 数 返 回 的 是 随机 抽取 的 单元 键 名 ， 并 不 是 单元 值 。 本 实例 的 关键 
| 代码 如 下 : 

<?php 

$array = array("php 函数 大 全 ""php 基础 实例 ","php 程序 设计 ","php 典型 案例 "); 

if($_ POST){ 


技术 要 点 


$result = array_rand($array, 3); 
echo "三 本 书 分 别 为 : ".$array[$result[0]]."，".$array[$result[1]]."，".$array[$result[2]]; 


本 实例 主要 使 用 了 array_rand0 函 数 , 该 函数 主要 用 于 从 数组 中 随机 取出 一 个 或 多 个 单 


元 。 如 果 只 取出 一 个 ， 则 返回 一 个 随机 单元 的 键 名 ; 否则 ,返回 一 个 包含 随机 键 名 的 数组 。 
| 这样 就 可 以 随机 从 数组 中 取出 键 名 和 值 。array_rand0 函 数 的 语法 格式 如 下 : 


实例 说 明 


| 个 彩票 抽奖 的 大 摇 箱 ， 在 原理 上 两 者 确 是 没有 什 SGrIEEaaaw ETo IE 二 
| 么 区 别 的 , 但 是 彩票 抽奖 的 大 摇 箱 可 能 存在 一 点 | 
| 点 的 偶然 性 ， 例 如 ， 大 摇 箱 里 的 球 弹力 不 同等 。 
| 本 实例 通过 随机 函数 rand0 实 现 随机 抽取 数组 中 


mixed array_Iand ( array input [, int num req]); 


参数 说 明 : 
回 input: 必 选 参数 ， 输 入 的 数组 。 
回 num_ req: 可 选 参 数 ， 指 明 想 取出 多 少 个 单元 ， 如 果 没有 指定 ， 默 认为 1。 


实例 152 车 牌 枚 号 


( 实例 位 置 : 配套 资源 \SL\08\152 ) 


我 们 可 以 把 随机 抽取 数组 中 的 元 素 看 成 一 


[ 曾 二 miE3 - Windows Intemet Explorer 


六 % 杯 * 而 于 有 三 1 :全 "上 加" 己 “| 


车 牌号 码 ，Amay([o] =>00000 [1]=>11111[2]=> 下 
22222 [3] => 33333 [4] => 66666 [s] => 88888 ) L 
随机 取得 车 牌号 码 : 66666 


重 ” 丽 105% > | 


| 实现 过 程 


创建 PHP 脚本 。 首先 定义 数组 变量 并 为 数组 变量 赋值 ， 然 后 利用 rand0 函 数 获取 0 一 4 
中 的 一 个 随机 数 , 并 将 此 随机 数 赋 给 数组 变量 作为 数组 变量 的 键 值 , 最 后 输出 此 数组 变量 。 
其 代码 如 下 : 
<2?php 
S$numbers = array(00000',"11111',22222','33333'"66666.,88888)): 
echo "车 牌号 码 : ": 
Print r($numbers); 
"230 。 
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Srand = rand(0,6); 
echo "<br> 随 机 取得 车 牌号 码 :".$numbers[$rand]; 
Wy 
技术 要 点 | a 
随机 获取 数组 中 的 元 素 ， 可 以 用 randO 函 数 获取 随机 数值 ， 并 将 随机 数值 指向 数组 下 ， 
标 ， 从 而 实现 随机 获取 指定 元 素 的 值 。rand0 函 数 的 语法 如 下 : 
int rand ( [int min, int max]): 
参数 说 明 : 
回 intmin: 随机 数 的 最 小 值 。 | 
int max: 随机 数 的 最 大 值 。 | 


实例 153 获取 上 传 文件 的 数据 


( 实例 位 置 : 配套 资源 \SL\08\153 视频 位 置 : 配套 资源 \SP\08\153 ) 


实例 说 明 

获取 上 传 文件 的 数据 ， 需 要 使 用 $_FILES[] 全 
局 数组 中 的 $_FILES["file"]["name"] 来 实现 。 本 实 
例 使 用 该 全 局 数组 获取 上 传 文件 的 名 称 , 运行 结果 
如 图 8.4 所 示 。 


现 过 程 


具体 步 又 如 下 : 
(1) 创建 index.php 文件 ， 并 设计 表单 页 面 。 图 8.4 获取 上 传 文件 的 数据 
(2) 编写 实现 代码 ， 具 体内 容 如 下 : 


< 


iisset($_ POST['Submit]) and $_ POST['Submit] 一 "获取 上 传 文件 名 ?5{ /判断 按钮 的 值 是 否 存 | 
在 ， 是 否 为 空 | 
echo $_FILES["file"]["name"]; // 输 出 上 传 文件 名 


} 
> 
技术 要 点 | 
本 实例 主要 使 用 了 $_FILES 中 全 局 数组 中 的 $_FILES["file"]["name"]， 与 其 他 全 局 数组 | 
不 同 ，$_FILES[ ] 全 局 数组 为 一 个 多 维 数 组 ， 该 数组 用 于 获取 通过 POST 方式 上 传 文件 时 | 
的 相关 信息 。 如 果 为 单 文件 上 传 ， 则 该 数组 为 二 维 数 组 ， 如 果 为 多 文件 上 传 ， 则 该 数组 为 | 
三 维 数组 。 下 面 对 该 数组 的 具体 参数 取 值 进行 介绍 。 | 
$_FILES["file"]["name"]: 从 客户 端 上 传 的 文件 名 称 。 
回 $_FILES["file"]["type"]: 从 客户 端 上 传 的 文件 类 型 。 
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SR 
回 $ FILES["userfile"]["size"]: 已 上 传 文件 的 大 小 。 

回 $_ FILES["file"]["tmp_name"]: 文件 上 传 到 服务 器 后 ， 在 服务 器 中 的 临时 文件 名 。 
回 $FILES["file"]["error"]: 返回 在 上 传 过 程 中 发 生 错 误 的 错误 代号 。 


实例 154 $_FILES[] 人 多 局 数组 在 文件 上 传 中 的 应 用 
( 实例 位 置 配套 资源 \SL\08\154 视频 位 置 配套 资源 \SP\08\154) 


| 实例 说 明 

| 在 开发 文件 上 传 的 程序 时 , 为 了 保证 上 传 文件 的 安全 、 合理 , 需要 对 上 传 文件 的 大 小 、 
| 类 型 和 名 称 等 进行 限制 ， 同 时 ， 还 要 在 上 传 失 败 时 给 出 一 个 正确 的 错误 提示 信息 。 所 有 这 
| 些 操作 都 可 以 通过 $_FILES[ ] 全 局 数组 来 完成 。 

| 开发 一 个 单 文件 上 传 的 实例 , 并 应 用 $_FILES[] 全 局 数组 获取 上 传 文件 在 客户 端的 名 称 
| 和 在 服务 器 端的 临时 名 称 , 同时 根据 $_FILES[] 全 局 数组 返回 的 错误 代码 给 出 正确 的 错误 提 
| 示 信 息 。 其 运行 效果 如 图 8.5 所 示 。 
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对 各 上 代 文 件 : DAProgram FiesiTencent [ 浏览] 


上 传 文件 
EE ED 


文 牢 160_0076jps 上 人 成功 ， 大 小 为: 32089:6 


Copyright 1999-2010 吉林 省 明日 科技 有 限 公司 


图 8.5 获取 上 传 文件 的 数据 


| 实现 过 程 

| 具体 步骤 如 下 
| (1) 创建 index.php 文件 。 首 先 添加 表单 ， 设 置 表单 的 enctype 属性 值 为 “multipart/ 
”form-data”。 然 后 设置 action 属性 值 为 POST， 并 添加 隐藏 域 限制 上 传 文件 的 大 小 、 添 加 文 
| 件 域 选 择 上 传 文件 。 最 后 添加 提交 按钮 ， 将 数据 提交 到 本 页 。 

| (2) 通过 $_FILES[ ] 全 局 数组 获取 上 传 文件 的 相关 信息 ， 通 过 is_dir0 和 mkdir0 判 断 、 
| 创建 上 传 文件 存储 的 目录 ， 通 过 time0 和 strstr0 函 数 定义 上 传 文件 在 服务 器 中 的 名 称 ， 通 
| 过 is_uploaded_file0 函 数 判 断 文 件 是 否 为 HTPP POST 上 传 ， 通过 move_upload file0 函 数 
| 完成 文件 上 传 。 具 体 代码 如 下 : 


<?php 
这 !empty($_FILES[mp_picture][mame])){ /判断 上 传 内容 是 否 为 空 
这 $_FILES[up_picture]['error]>0){ /判断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错误 :": 


| switch($_FILES["up_picture']['error]){// 根 据 $_FILES[ ] 全 局 数组 返回 的 错误 代码 , 输出 不 同 的 错 
J 。232 。 
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误 信息 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break:; 
Case 2: 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 
Case 3: 
echo "上 传 文件 不 全 "; 
break; 
Case 4: 
echo "没有 上 传 文件 "; 
break; 
上 
}else{ 
if(!lis_dir("./upfile/"){ // 判 断 指定 目录 是 否 存在 
mkdir("./upfile/"); // 创 建 目 录 
} 
$path='./upfile/'.time(O.strsr($_FILES['up_picture"][name"],…);// 定 义 上 传 文件 名 称 和 存储 位 置 | 
iftis_uploaded_file($_FILES["up_picture"]['tmp_name"])){// 判 断 文件 是 否 为 HTPPPOST 上 传 | 
if(!move_uploaded file($ FILES["up_picture']['tmp_name'],$path)){ // 执 行 上 传 操作 
echo "上 传 失 败 "; | 
jelse{ | 
echo "文件 ".$_FILES[up_picture'][mame']." 上 传 成 功 , 大 小 为 : ".$_FILES["up_picture'] | 
[size]; | 
}; 
}else{ 
echo "上 传 文件 ".$_FILES[up_pictute][mame']." 不 合法 ! "; 
} 
} 
上 
人 


本 实例 对 PHP 的 各 种 知识 进行 了 整合 应 用 ， 包 括 流程 控制 语句 〈 计 和 switch)、 数 组 
($_FILES[] 全 局 数组 )、 文 件 系统 函数 (id_dir0)、mkdir0)、is_uploaded file0 和 move | 
uploaded file0)、 日 期 时 间 函 数 (time0) 和 字符 串 函 数 (strstr0)。 | 


实例 155 图 书信 息 送 向 输出 


( 实例 位 置 : 配套 资源 \SL\08\155 ) 


实例 说 明 | 

在 图 书 列表 中 , 将 php 书籍 以 列表 的 形式 随机 存储 到 数组 中 , 如 图 8.6 所 示 。 单 击 “ 逆 

序 排列 ”按钮 ， 应 用 arsort0 函 数 按 图 书 名 称 进行 逆向 排序 (由 高 到 低 )， 获 取 的 结果 列表 | 

如 图 8.7 所 示 。 | 
:533s L_ 
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B ook Book 
| se 了 到 大 全 sh 医大 全 ER 
Php 基础 闪 例 php 基础 实例 PhF 国 数 庆 主 
Php 程序 设计 php 程序 设计 Fhp 上 典型 案例 
A | he 典型 案 网 php 寺 型 宁 全 phr 程 尺 设 计 
图 8.6 php 图 书 列表 图 8.7 逆向 排序 后 的 图 书 列表 
| 实现 过 程 
| arsort0 函 数 排序 的 对 象 是 数组 中 的 值 , 并 保持 索引 和 其 对 应 值 的 关联 关系 , 代码 如 下 : 
<2php 
$array = array("php 函数 大 全 ","php 基础 实例 ","php 程序 设计 ","php 典型 案例 "); 
if($_POST){ 
arsort($array); 
echo '<table border="0" cellpadding="0" cellspacing="1" bgcolor="#AAAAAA">' 
foreach($array as $value){ 


echo '<tr align="center"> 
<td width="120" height="30" bgcolor="#FFFFFF">'.$value.'</td> 


</tr>'; 
echo '</table>'; 
} 
| > 
| 技术 要 点 


| 对 数组 进行 逆向 排序 ， 数 组 的 索引 保持 和 单元 的 关联 ， 主 要 用 于 对 那些 单元 顺序 很 重 
| 要 的 数组 进行 逆向 排序 。 
| 语法 如 下 : 
Void arsort ( array array [, int sort_flags]) 
参数 说 明 : 
回 array: 必 选 参数 ， 输 入 的 数组 。 
回 sort flags: 可 选 参数 ， 可 改变 排序 的 行为 ， 排 序 类 型 标记 。 
> SORT REGULAR: 正常 比较 单元 。 
> SORT_NUMERIC: 单元 被 作为 数字 来 比较 。 
> ”SORT_STRING: 单元 被 作为 字符 串 来 比较 。 


实例 156 统计 图 书 的 数量 


( 实例 位 置 : 配套 资源 \SL\08\156 ) 


| 实例 说 明 
| 在 图 书 统计 列表 页 面 中 ,将 图 书 的 数据 存放 在 数组 中 ， 并 应 用 count0 函 数 对 数组 中 的 
| .234 。 
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图 书 数量 进行 统计 ， 单 击 “ 统 计 图 蔬 ”按钮 ， 即 可 条 出 图 书 的 总 数量 ， 运 行 结果 如 图 8.8 | 
所 示 。 


回 省 统 并 
ee 
hp 程 厚 设计 
FhF 幅 型 案例 

ss 
图 8.8 统计 图 书 的 数量 
实现 过 程 
具体 步骤 如 下 : 


(1) 创建 index.php 文件 ， 并 设计 表单 页 面 。 
(2) 编写 实现 代码 ， 本 实例 的 关键 代码 如 下 : 
<2php | 
$array = array("php 函数 大 全 ","php 基础 实例 ","php 程序 设计 ","php 典型 案例 ","asp 基础 实例 ","asp | 
程序 设计 | 
if($_POST){ 


$result = count($array); 


echo "一 共有 图 书 $result 本 "; 
?> 
技术 要 点 
count(O) 函 数 用 于 返回 数组 中 的 单元 数目 ， 用 来 计算 数组 中 值 的 个 数 。 该 函数 的 语法 格 
式 如 下 : | 
int count ( mixed array [, int mode]) 


参数 说 明 : 

回 array: 必 选 参数 ， 输 入 的 数组 。 | 

回 mode: 可 选 参数 ，COUNT RECURSIVE (或 1) ， 如 选中 此 参数 ， 本 函数 将 递 | 
归 地 对 数组 计数 ， 对 计算 多 维 数组 的 所 有 单元 尤其 有 用 ， 此 参数 的 默认 值 为 0。 | 


实例 157 获取 图 书馆 中 最 受 欢 迎 的 3 本 图 书 


( 实例 位 置 : 配套 资源 \SL\08\157 ) 


本 实例 将 图 书馆 内 php 书籍 的 列表 及 借阅 人 数 随机 存放 到 数组 中 , 应 用 lasortO 函 数 对 | 
图 书 进行 逆向 排序 ， 然 后 返回 排序 好 的 数组 列表 ， 再 应 用 amay values0 函 数 取出 数组 的 值 | 
. 235 . 
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并 重 设 数字 索引 ， 因 为 list0 函 数 仅 用 于 数字 索引 并 从 0 开始 , 最 后 应 用 list0 函 数 获取 最 受 
| 读者 欢迎 的 3 本 php 图 书 ， 如 图 8.9 所 示 。 


区 三 丰 书 : He 函数 大 全 ，pbg 程 友 设 十，plp 失 于 守重 


| 图 89 获取 图 书馆 中 最 受 欢迎 的 3 本 书 
| 实现 过 程 

| 具体 步骤 如 下 : 

(1) 创建 index.php 文件 ， 并 设计 表单 页 面 。 

(2) 编写 实现 代码 ， 本 实例 的 关键 代码 如 下 : 


<2php 
| $amray= amray("68 人 "=>"php 函数 大 全 ""23 人 "=>"php 基础 实例 ""56 人 "=>"php 程序 设计 ","55 人 "=>"php 
| 典型 案例 "); 
| 这 $_ POST){ 
krsort($array); // 数 组 排序 
$result = array_values($array): // 获 取 数 组 的 值 
list($first,$second,$third) = $result:; // 遍 历数 组 
echo " 受 读者 欢迎 的 三 本 书 : $first ，$second ，Sthird"; 
} 
| ?> 
| 技术 要 点 


把 数组 中 的 值 赋 给 一 些 变量 。 与 array0 函 数 类 似 ,， 这 不 是 真正 的 函数 ， 而 是 语言 结构 。 
list0 函 数 仅 能 用 于 数字 索引 的 数组 ， 且 数字 索引 从 0 开始 。 
语法 如 下 : 
void list ( mixed ...) 
”参数 mixed 为 被 赋值 的 变量 名 称 。 


实例 158 生成 在 线 考试 题 


( 实例 位 置 : 配套 资源 \SL\08\158 ) 


| 实例 说 明 


| 考试 题 的 添加 以 字符 串 的 形式 进行 提交 ， 每 个 考试 题 之 间 以 * 进 行 分 隔 ， 然 后 应 用 
| explode0 函 数 将 字符 串 转换 成 数组 ， 最 后 通过 for 循环 语句 和 count0 函 数 完成 考试 题 的 输 
| 出 ， 运 行 结果 如 图 8.10 所 示 。 
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【入 再][ 硕 动 ] [有 出 ] 
1 训 出 系统 


计 时 : 13:22 


图 8.10 考试 题 输 出 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 index.php 文件 ， 并 设计 表单 页 面 。 
(2) 编写 实现 代码 ， 具 体内 容 如 下 : 
<?php 
if($_POST[Submit]!="){ 
$content=$_POST[content]; // 获 取 表 单 提交 的 数据 


$data=explode("*",$content); Jexplode 函数 对 数据 进行 拆 分 ， 以 * 号 为 分 隔 符 
for($i=0;$i<count($data);$i++){ //for 循环 输出 数组 中 的 数据 
echo $data[$i]."<br><br>"; // 输 出 元 素 值 


本 实例 主要 使 用 了 explode0 函 数 和 countO 函 数 。 

(1) explode() 函 数 。 
explodeO 函 数 的 作用 是 使 用 指定 的 分 隔 符 来 分 割 字 符 串 ， 同 时 将 分 割 后 的 字符 串 存 成 | 
数组 并 返回 。 | 


array explode ( string separator, string string [, int limit] ) 
参数 说 明 : 
回 ”separator: 是 要 使 用 的 分 隔 符 ， 可 以 是 单个 字符 ， 也 可 以 是 一 个 字符 串 。 
回 string， 表 示 的 是 要 分 割 的 字符 。 
回 limit， 表示 要 分 割 的 个 数 ， 如 果 limit 参数 是 负数 ， 则 返回 除了 最 后 的 limit 个 元 | 
素 外 的 所 有 元 素 。 | 
(2) count0 函 数 。 
count(O) 函 数 返回 数组 中 的 单元 数目 ， 用 来 计算 数组 中 值 的 个 数 。 
语法 如 下 : 


int count ( mixed array [, int mode]) 
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eh 
参数 说 明 : 
回 array: 必 选 参数 ， 输 入 的 数组 。 
| 回 ” mode: 可 选 参数 ，COUNT RECURSIVE (或 1) ， 如 选中 此 参数 ， 本 函数 将 递 
其 归 地 对 数组 计数 ， 对 计算 多 维 数组 的 所 有 单元 尤其 有 用 ， 此 参数 的 默认 值 为 0。 


EC + 


电子 商务 系统 中 的 购物 车 同 实际 生活 中 的 购物 车 一 样 ， 都 是 用 于 暂时 保存 挑选 的 商 
| 品 。 购物 车 主要 包括 所 选 商品 的 添加 、 查 看 购物 车 、 商 品 购买 数量 的 修改 、 从 购物 车 移 去 
Ee 清空 购物 车 5 部 分 。 用户 单 击 商品 展台 中 的 “ 放 入 购物 车 ” 超 链 接 ， 可 以 将 对 
| 应 的 商品 添加 至 购物 车 。 在 查看 购物 车 页 面 中 ， 单 击 “ 移 除 ” 超 链接 可 以 从 购物 车 中 移 去 
| 指定 商品 ; 在 “数量 ”文本 框 中 输入 购买 数量 后 ， 单 击 “ 更 改 商 品 数量 ”按钮 即 可 修改 指 
| 定 商 品 的 购买 数量 ; 单 击 “ 清 空 购物 车 ” 超 链接 ， 将 退回 购物 车 中 的 全 部 商品 ; 如 果 用 户 
| 确认 购买 当前 购物 车 中 的 全 部 商品 ， 可 以 单 击 “ 去 收银 台 ” 超 链接 ， 进 行 订单 处 理 。 
| 下 面 通过 具体 的 实例 159 ~ 实例 164 来 向 读者 讲解 如 何 应 用 PHP 数组 和 SESSION 变 
| 量 共同 实现 购物 车 的 全 部 功能 。 


实例 139 向 购物 车 中 添加 商品 


( 实例 位 置 : 配套 资源 \SL\08\159-164 视频 位 置 : 配套 资源 \SP\08\159-164 ) 


| “添加 至 购物 车 ”页 主要 用 于 将 商品 信息 暂时 保存 到 购物 车 中 ， 而 且 在 一 些 电子 商务 
| 网 站 中 ， 它 是 客户 端 程序 中 非常 关键 的 一 个 功能 ， 主 要 用 来 帮助 用 户 完成 商品 的 选 购 。 本 
| 实例 中 的 购物 车 是 采用 自 定义 函数 cart0 来 存储 购物 数据 的 ， 购 物 信息 被 保存 在 SESSION 
| 中。 运行 本 实例 ， 用 户 单 击 “ 放 入 购物 车 ”按钮 ， 即 可 将 商品 添加 到 购物 车 中 ， 运 行 结果 
| 如 图 8.11 所 示 ， 用 户 可 以 单 击 “ 首 页 ” 超 链接 继续 选 购 商 品 。 本 实例 中 ， 对 于 同一 商品 的 
| 多 数量 选 购 , 可 以 直接 在 购物 车 中 对 其 数量 进行 更 改 , 而 不 可 以 多 次 将 商品 放 入 购物 车 中 。 


ss 


会 品 谷 1990 元 


i 


| 图 8.11 向 购物 车 中 添加 商品 
实现 过 程 
| 用 户 看 好 一 件 商品 但 又 没有 确定 买 不 买 时 ， 就 可 以 将 商品 先 放 进 购 物 车 中 。 下 面 将 介 


了 。238 。 
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绍 如何 将 商品 添加 至 购物 车 。 

(1) 当 用 户 登 录 到 网 站 时 ， 系 统 将 为 每 个 用 户 分 配 两 个 SESSION 变量 $producelist 
和 $quatity， 分 别 用 来 存储 用 户 放 入 购物 车 中 的 商品 ID 和 商品 的 数量 。 一 个 变量 同一 时 刻 
只 能 有 一 个 值 ,那么 如 何 将 多 个 ID 值 同时 保存 在 一 个 $producelist 变量 中 呢 ? 首先 将 ID 转 
变 成 字符 型 变量 ， 并 且 将 这 些 变量 用 字符 “@” 进 行 连接 ， 比 如 用 户 分 别 将 了 为 1、3、5 
的 商品 放 入 购物 车 中 ， 这 时 SESSION 变量 $producelist 的 值 应 该 为 “1@3@5@”。 然 后 ， 
用 函数 explode0 完 成 ID 的 提取 ， 并 且 判 断 用 户 提 交 的 ID 值 在 $producelist 变量 中 是 否 存 
在 ， 如 果 存 在 则 给 出 提示 信息 ， 和 否则 可 以 执行 添加 操作 。addgouwuche.php 的 代码 如 下 : 


<2?php 
session start(); // 开 启 会 话 
$id=strval($_GET["id"]); /获取 商品 瑟 值 


/将 SESSION 变量 $producelist 中 的 内 容 用 字符 “@” 进 行 分 割 ， 并 将 结果 保存 在 数组 $array 中 
$array=explode("@",$_ SESSION["producelist"]): 
for($i=0;$i<count($array)-1;$i++) { /循环 输出 数组 中 的 元 素 
if($array[$i]=$id){// 如 果 $array 数组 中 存在 与 $id 相等 的 元 素 ， 说 明 该 $id 所 对 应 的 商品 已 经 
在 购物 车 中 
echo "<script>alert(' 该 商品 已 经 在 您 的 购物 车 中 !"):history.backO0:</script>"; 
exit: 


} 


b 
// 如 果 该 商品 不 在 购物 车 中 ， 则 将 该 商品 的 ID 值 连接 到 SESSION 变量 $producelist 之 后 ， 并 用 
“@” 进 行 分 割 

$_SESSION['producelist]=$_SESSION['producelist].$id."@"; 

/同时 将 该 商品 的 数量 用 “@” 进 行 分 割 保存 在 SESSION 变量 $quatity 中 ， 并 将 默认 数量 设置 为 1 

$_SESSION[quatity]-$_SESSION[quatity] "1@": 

header("location:shopcarphp"); /添加 成 功 之 后 将 该 页 定位 到 shopcarphp 页 面 显 示 购 物 车 中 
的 内 容 


了 
技术 要 点 
将 商品 添加 至 购物 车 其 关键 是 应 用 会 话 创 建 SESSION 变量 ， 为 用 户 分 配 购物 车 ， 然 
后 应 用 explode0 函 数 向 购物 车 中 添加 数据 ， 最 后 通过 for 语句 和 countO 函 数 检测 购物 车 中 
是 否 存 在 用 户 提交 的 商品 。 
(1) 通过 session start0 函 数 初始 化 SESSION 变量 ， 通 过 $ SESSION[] 直 接 为 变量 赋值 。 
(2) explode() 函 数 ， 按 照 指定 的 规则 对 一 个 字符 串 进行 分 割 ， 返回 值 为 数组 。 其 语法 
如 下 : 
array explode(string separator,string str,[int limit]) 
explode0) 函 数 的 参数 说 明 如 表 8.1 所 示 。 


表 8.1 explode() 函 数 的 参数 说 明 


设 置 值 描 述 


必 选 参数 ， 指 定 的 分 割 符 。 如 果 separator 为 空 字符 串 〈"") ，explode0 将 返回 false。 如 果 
separator 所 包含 的 值 在 str 中 找 不 到 ， 那 么 explode0 函 数 将 返回 包含 str 单个 元 素 的 数组 


separator 


“29s 
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续 表 


设 置 值 描 述 


str | 必 选 参数 ， 指 定 将 要 被 分 割 的 字符 中 


可 选 参数 ， 如 果 设 置 了 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 的 元 素 将 包 
含 string 的 剩余 部 分 ; 如 果 limit 参数 是 负数 ， 则 返回 除了 最 后 的 -limit 个 元 素 外 的 所 有 元 素 


limit 


(3) count0 函 数 。 
int count(mixed var) 
count() 函 数 的 作用 是 用 来 计算 变量 var 中 元 素 的 个 数 。 如 果 变 量 为 空 ， 则 返回 0， 如 
果 变 量 是 数组 ， 则 返回 数组 元 素 的 个 数 ， 如 果 是 普通 型 变量 ， 则 返回 1。 


指点 迷津 : 
上 面 说 到 的 ID 指 的 是 tb shangpin 表 中 的 ID 字段 。 


实例 160 ”查看 购物 车 


( 实例 位 置 : 配套 资源 \SL\08\159-164 视频 位 置 : 配套 资源 \SP\08\159-164 ) 


实例 说 明 

用 户 选 购 完 商 品 后 ， 为 了 方便 用 户 随时 查看 所 选 购 的 商品 ， 可 以 通过 查看 购物 车 来 查 
看 当前 用 户 购物 车 中 的 商品 信息 。 在 导航 条 中 单 击 “ 购 物 车 ” 超 链接 ， 即 可 打开 “查看 购 
物 车 ”页 面 。 运行 结果 如 图 8.12 所 示 。 


图 8.12 查看 购物 车 


实现 过 程 
在 shopcarphp 页 面 中 ， 实 现 查看 购物 车 功能 ， 首 先 需要 判断 购物 车 是 否 为 空 ， 如 果 为 
空 ， 需 要 将 页 面 重 定向 到 购物 车 首页 面 ， 否 则 显示 购物 车 信息 ， 主 要 将 保存 在 SESSION 
中 的 购物 信息 应 用 for 循环 语句 输出 到 浏览 器 中 。 其 关键 代码 如 下 : 
<?php 
session register("total"): /注册 SESSION 变量 $total 用 来 保存 所 有 商品 价格 总 和 


if($_GET['qk']—"yes"){ // 判 断 用 GET 方法 提交 的 qk 的 值 是 否 为 yes， 如 是 则 使 $producelist 
和 $quatity 的 值 为 空 串 ， 才 $_SESSION["producelist"]=""; 
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$_SESSION["quatity"]=": 


} 
$arraygwc=explode("@",$_ SESSION[producelist]); 
$s=0; // 用 $s 保存 购物 车 中 商品 了 D 的 总 和 
for($i=0:;$i<count($arraygwe):$i++){ 
$s+=intval($arrayegwc[$1i]):; 
1 
这 $s 一 0 ) { /如 果 $s 的 值 为 定 ， 则 说 明 购物 车 中 无 商品 
echo "<tr>"; | 
echo" <td height='25' colspan='6' bgcolor='#FFFFF' align='center> 您 的 购物 车 为 室 !</td>"; | 
echo"</tr>"; | 
}else { /如 果 $s 的 值 不 为 室 ， 则 显示 购物 车 中 所 有 商品 信息 | 
ge ! 
<! -省 略 部 分 代码 --> | 
<2php 
S$total=0; // 初 始 化 $total 变量 
$array=explode("@",$_SESSION["producelist"]); // 分 离 购物 车 中 的 商品 人 D 
$arrayquatity=explode("(@",$_SESSION["quatity"]); 。“ // 分 离 购 物 车 中 的 商品 数量 
while(list($name, $value)=each($_POST)) { // 获 取 POST 传递 值 
for($i=0;$i<count($array)-1;$1++){ 
if((Sarray[$i])—$name){ 
S$arrayquatity[$i]=$value; 
} 
} 
$_SESSION["quatity"]=implode("(@",$arrayquatity); /更 新 购物 车 中 商品 数量 
for($i=0:$i<count($array)-1:$i++) { // 循 环 输出 
S$id=$array[$i]; 
Snum=$arrayquatity[$i]; 
if($id!="){ | 
$sql=mysql_query("select * from tb_shangpin where id=".$id."",$conn); // 执 行 数据 | 
库 操作 命令 | 
$info=mysql_fetch_array($sql); /执行 数据 库 操作 | 
S$totall=$num*$info["huiyuanjia"]; // 计 算 会 员 价格 | 
S$total+=$totall; // 增 加 商品 总 价格 | 
$_ SESSION["total"]=$total: /将 商品 总 价格 赋值 给 $_SESSION["total"] 变 量 | 
9 | 
<! -省 略 部 分 代码 --> | 
<2php | 
) 
) 
> 
技术 要 点 | 


查看 购物 车 的 开发 思路 :首先 判断 购物 车 是 否 为 空 ， 如 果 为 空 ， 则 显示 “您 的 购物 车 | 
为 空 !” 的 提示 信息 否则 ， 将 SESSION 数组 中 的 购物 信息 显示 到 页 面 中 。 

(1) 通过 explode0 函 数 获取 购物 车 中 存储 的 商品 ID 和 商品 数量 。 

(2) 通过 implode0 函 数 更 新 购物 车 中 商品 的 数量 。 
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ge 
implode0 函 数 ， 将 数组 中 的 元 素 组 合成 一 个 新 字符 串 。 其 语法 如 下 : 
string implode(string glue, array pieces) 
人 | 参数 glue 是 字符 串 类 型 , 指定 分 隔 符 ; 参数 pieces 是 数组 类 型 , 指定 要 被 合并 的 数组 。 
全 | ， ”G3) 创建 s SESSION["totalq] 变 量 ， 存 储 商 品 的 总 价 数据 。 


实例 161 从 购物 车 中 移 去 指定 商品 


( 实例 位 置 : 配套 资源 \SL\08\159-164 ”视频 位 置 : 配套 资源 \SP\08\159-164 ) 


| “在 购物 过 程 中 ， 顾 客 想 将 已 经 选择 的 商品 退回 到 货物 架 上 是 商品 选 购 时 经 常 发 生 的 事 
| 情 。 因 此 ， 在 开发 一 个 电子 商城 网 站 时 ， 必 须 考虑 到 这 一 点 ， 做 好 需求 分 析 ， 从 而 使 网 站 
| 更 加 完善 。 那 么 本 实例 在 设计 购物 车 时 又 是 如 何 实现 从 购物 车 中 移 去 指定 商品 的 呢 ? 这 就 
| 需要 在 查看 购物 车 页 面 中 添加 一 个 将 指定 商品 退回 的 功能 ， 即 从 购物 车 中 移 去 指定 商品 
| 运行 结果 如 图 8.13 所 示 。 


图 8.13 ”从 购物 车 中 移 去 指定 商品 


| “具体 步骤 如 下 : 
| (1) 在 shopcarphp 页 面 的 “购物 车 ”中 添加 “ 移 除 ” 超 链 接 ， 链 接 到 removegwc.php 
| 文件 中 ， 根 据 超 链接 传递 的 ID 值 完成 对 指定 商品 的 删除 操作 。 创 建 超 链接 的 代码 如 下 : 

| <a href="removegwc.php?id=<?php echo $info["id']?>"> 移 除 </a> 


| (2) 在 removegwc.php 文件 中 ， 首 先 用 函数 explode0 将 SESSION 变量 $producelist 
| 以 “@” 进 行 分 割 ， 并 把 分 割 出 的 子 串 存放 到 数组 中 ， 然 后 将 用 户 要 删除 的 商品 对 应 的 数 
| 组 元 素 赋予 空 值 ， 最 后 将 数组 元 素 重 新 组 合成 新 串 ， 即 完成 指定 商品 的 移 除 操作 。 其 关键 
| 代码 如 下 : 

| <2php 


session start(); 

$id=$_GET["id']; // 获 取 用 户 打算 移 去 商品 的 了 
S$arraysp=explode("(@",$_SESSION["producelist"]); 

$arraysl=explode("@".$_SESSION["quatity"]): // 分 别 将 购物 车 中 的 商品 卫 和 对 应 商品 的 数 
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量 存放 到 数组 $arraysp 和 $arraysl 中 
for($i=0:$i<count($arraysp):$i++) { 
这 $arraysp[$i] 一 $id) { // 通 过 循环 寻找 与 ID 值 相等 的 数组 元 素 
Sarraysp[$1]=""; 
Sarraysl[$i]=""; /将 与 ID 值 相等 的 数组 元 素 赋予 空 值 
} 


$_SESSION["producelist"]=implode("(@",$arraysp); 
$_SESSION["quatity"]=implode("@",$arraysl); /利用 implode0 函 数 将 数组 元 素 重 新 组 合成 新 串 


header("location:shopcar.php"); // 重 新 定位 到 shopcarphp 显示 购物 车 
?> 


本 实例 实现 从 购物 车 中 移 去 指定 商品 ， 主 要 应 用 for 循环 语句 将 用 户 指 定 商品 的 数组 
元 素 赋予 空 值 ， 代 码 如 下 : | 
for($i=0:$i<count($arraysp):$i+H) { 


这 $arraysp[$i] 一 $id) { // 通 过 循环 寻找 与 ID 值 相等 的 数组 元 素 
$arraysp[$1]=""; 
Sarraysl[$i]=""; /将 与 ID 值 相等 的 数组 元 素 赋 予 空 值 

bE 

} 


实例 162 修改 商品 购买 数量 


(实例 位 置 : 配套 资源 \SL\08\159-164 ”视频 位 置 配套 资源 \SP\08\159-164 ) 


实例 说 明 | 
为 了 满足 用 户 的 不 同 需求 ， 购 物 车 中 还 需 加 入 修改 指定 商品 购买 数量 的 功能 。 在 购物 
车 中 ， 由 于 商品 的 数量 被 存放 在 文本 框 里 ， 用 户 只 需 在 某 种 商品 后 面 的 文本 框 中 输入 相应 | 
的 数量 即 可 。 例 如 ， 在 本 实例 中 ， 将 数码 摄像 机 的 数量 改 为 2 台 ， 然 后 单 击 “ 更 改 商 品 数 
量 ” 按 钮 ， 即 可 成 功 修改 商品 的 购买 数量 ， 运 行 结果 如 图 8.14 所 示 。 


图 8.14 修改 商品 购买 数量 


实现 过 程 | 
购物 车 中 的 商品 默认 数量 是 1， 如 果 用 户 打 算 购 买 多 件 相 同 的 商品 ， 就 需要 对 购物 车 
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中 商品 数量 变量 的 值 进行 修改 。 在 shopcarphp 文件 中 , 修改 商品 购买 数量 是 将 购物 车 中 某 
件 商品 对 应 的 数组 元 素 赋予 新 值 。 其 关键 代码 如 下 : 


while(list($name, $value)=each($ POST)) { // 提 取 表 单 中 的 商品 DD 和 新 数量 
for($1=0;$1<count($array)-1;$i++) { 
if(($array[$i])—$name) { 
$arrayquatity[$i]=$value; // 获 取 购物 车 中 每 种 商品 的 数量 ， 并 将 数量 保存 到 $arrayquatity 数组 中 
} 
} 


! 
$_SESSION['quatity']=implode("@",$arrayquatity); // 将 更 新 后 的 数据 保存 到 购物 车 中 
要 实现 购物 车 中 商品 数量 的 更 新 ， 前 提 是 必须 通过 表单 来 提交 指定 商品 的 ID 和 要 更 
新 的 数量 ， 和 否则 更 新 操作 不 会 被 执行 。 提 交 商 品 ID 和 更 新 数量 的 表单 如 下 : 
<form name="forml" method="post" action="shopcar.php"> 
<input type="text" name="<?php echo $info['id'];?>" size="2" class="inputcss" value=<?php echo 
$num;?>> 
<input name="submit' type="submit" class="buttoncss" value=" 更 改 商 品 数量 "> 
</form> 
在 创建 添加 商品 数量 的 表单 元 素 时 ， 以 商品 ID 为 表单 元 素 的 名 称 ， 以 提交 的 商品 数 
量 为 表单 元 素 的 值 ， 最 终 将 数据 提交 到 shopcarphp 页 面 中 。 
技术 要 点 
本 实例 中 通过 list0 函 数 和 each0 函 数 获取 表单 提交 的 商品 ID 和 更 改 的 商品 数量 。 
listO 函 数 将 数组 中 的 值 赋 给 一 些 变量 ， 该 函数 仅 能 用 于 数字 索引 的 数组 ， 且 数字 索引 
从 0 开始。 其 语法 如 下 : 
void list (mixed ...) 
参数 mixed 为 被 赋值 的 变量 名 称 。 
each0O 函 数 返 回 数组 中 的 键 名 和 对 应 的 值 ， 并 向 前 移动 数组 指针 。 其 语法 如 下 : 
array each ( array array) 
参数 array 为 输入 的 数组 。 
在 语句 “list($name,$value)=each($_POST)” 中 ,变量 $name 为 指定 商品 的 ID ,变量 $value 
为 商品 更 新 的 数量 值 ， 而 $_POST 则 是 表单 提交 的 数据 。 


实例 163 ” 清 室 购物 车 


( 实例 位 置 : 配套 资源 \SL\08\159-164 视频 位 置 配套 资源 \SP\O8\159-164 ) 


实例 说 明 
在 实例 162 中 已 经 介绍 了 如 何 从 购物 车 中 移 去 指定 的 商品 ， 本 实例 将 介绍 一 种 如 何 将 
购物 车 中 全 部 商品 一 次 性 清空 的 方法 。 清 空 购物 车 的 实现 方法 很 简单 ， 只 需 将 保存 在 
SESSION 中 的 购物 信息 清空 即 可 ， 运 行 结果 如 图 8.15 所 示 。 
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图 8.15 清空 购物 车 


实现 过 程 | 
在 shopcarphp 页 面 中 ， 创 建 一 个 “清空 购物 车 ”的 超 链接 ， 链 接 到 shopcarphp 文件 

中 ， 设 置 超 链 接 参数 qk 的 值 为 yes。 超 链接 的 代码 如 下 : | 
<a href="gouwul.php?qk=yes"> 清 空 购物 车 </a> 


在 shopcarphp 页 面 中 ， 判 断 超 链接 变量 qk 是 否 被 设置 ， 变量 qk 的 值 是 否 等 于 yes， 如 
果 等 于 ， 则 执行 购物 车 的 清空 操作 ， 即 为 $_SESSION["producelist"] 和 $_SESSION["quatity"] | 
赋 空 值 。 其 关键 代码 如 下 : | 


ifisset($_GET[qk]) && $_ GET['qk] 一 "yesD){ ”// 判 断 用 户 是 耕 单 击 “ 清 空 购物 车 ” 


$_SESSION["producelist"]=""; // 清 空 购物 车 中 商品 卫 
$_SESSION["quatity"]=""; // 清 空 购物 车 中 商品 数量 
} 
技术 要 点 


本 实例 主要 是 通过 将 保存 商品 ID 和 商品 数量 的 SESSION 变量 清空 ， 从 而 完成 清 
物 车 的 功能 。 在 执行 这 个 操作 之 前 ， 应 用 isset0 函 数 判 断 超 链接 参数 变量 是 否 被 设置 ， 
为 只 有 超 链接 参数 变量 被 设置 的 情况 下 , 才能 执行 清空 操作 , 并 且 这 只 是 其 中 的 一 pb 
同时 还 必须 保证 变量 值 是 yes 才能 真正 执行 清空 操作 。 | 

isset0 函 数 ， 检 查 变量 是 否 被 设置 ， 返 回 值 为 true 或 false， 由 于 这 是 一 个 语言 结构 而 | 
非 函 数 ， 因 此 它 无 法 被 “变量 函数 ”调用 。 其 语法 如 下 : | 

bool isset ( mixed var [, mixed var [, ...]] ) 

参数 说 明 : 

回 var: 必 选 参数 ， 指 定 检测 的 变量 。 

回 var2: 可 选 参数 ， 指 定 多 个 被 检测 的 变量 。 


实例 164 收银 台 结 账 
( 实例 位 置 : 配套 资源 \SL\08\159-164 视频 位 置 配套 资源 \SP\08\159-164 ) 
实例 说 明 | 
如 同 在 超市 中 购物 一 样 ， 将 商品 保存 到 购物 车 中 并 不 是 网 上 购物 的 最 终 目 的 ， 而 到 收 
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| 银 台 结账 后 ， 才 算是 一 次 购物 过 程 的 最 终 完成 。 前 面 所 有 功能 都 是 为 最 后 生成 一 个 用 户 满 

| 意 的 订单 做 准备 。 生 成 订单 时 ， 不 仅 要 保存 用 户 订单 中 所 购买 的 商品 信息 和 订单 信息 ， 同 

| 时 还 需要 返回 一 个 订单 号 。 用 户 单 击 查看 购物 车 页 面 中 的 “去 收银 台 ” 超 链接 即 可 进入 到 
天 | 收银 台 结账 页 面 填写 订单 信息 。 订 单 信息 填写 完成 后 ， 单 击 “ 提 交 订单 ”按钮 ， 即 可 保存 
“YY 、” | 订单 信息 到 数据 表 中 ， 运 行 结果 如 图 8.16 和 图 8.17 所 示 。 
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六 方式 : 。 尖 人 上 站 变 伯 方式 : 网 上 雪 什 
得 修 在 一 周 内 按 迪 的 交付 方式 久生 江 革 , 江 藉 时 注 明 阁 的 订单 红 区 后 清 及 对 江 知 我们 
关闭 窗口 RR ;2007-04-28 07 53 31 


图 8.16 ”收银 台 结 账 图 8.17 商品 订单 
现 过 程 
在 shopcarphp 页 面 中 ， 单 击 “ 去 收银 台 ” 超 链接 ， 将 跳 转 到 cash_register.php 页 面 ， 
| 填写 订单 信息 ， 单 击 “ 提 交 订 单 ” 按 钮 将 订单 数据 提交 到 savedd.php 文件 ， 将 订单 的 概要 
| 信息 保存 到 订单 主 表 中 ， 同 时 返回 该 订单 编号 。 
(1) 创建 cash_register.php 页 面 , 生成 提交 订单 信息 的 表单 ,将 数据 提交 到 savedd.php 
文件 进行 处 理 。 表 单 的 设计 效果 如 图 8.18 所 示 。 


图 8.18 表单 设计 效果 


| (2) 创建 savedd.php 文件 ， 获 取 表 单 提交 的 订单 数据 ， 将 其 添加 到 指定 的 数据 表 中 ， 
| 并 且 生 成 订单 号 ， 数 据 添加 成 功 后 将 重新 定向 到 cash_register.php 页 面 ， 将 生成 的 订单 号 
| 作为 超 链接 的 参数 值 进行 传递 。savedd.php 的 关键 代码 如 下 : 


<?php 
Session _startO: /初始 化 SESSION 变量 
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include("conn/conn .php"): // 载 入 数据 库 连 接 文 件 

$dingdanhao=date("YmjHis"):; /根据 当前 时 间 戳 生成 订单 号 

$spc=$_ SESSION["producelist"]:; /获取 购物 车 数据 

$slc=$_SESSION["quatity"]: 

/省 略 部 分 代码 

if(trim($_POST["Iy"D—"){ 

S$leaveword=""; 
Jelse{ 
S$leaveword=$ POST["ly"]; 

上 

$xiadanren="Mrsoft"; 

$time=date("Y-m-j H:i:s"); 

$zt=" 未 作 任 何 处 理 "; 

S$total=$_SESSION["total"]; 

mysql_query("insert into tb_dingdan(dingdanhao,spc,slc,shouhuoren,sex,dizhi,youbian,tel,email,sh 人 ff 
zfff,leaveword,time,xiadanren,zt.total) values (‘$dingdanhao','$spe','$slc','$shouhuoren','$sex','$dizhi','$youbian', 


'$tel','$email','$shff ,'$zfff,'$leaveword','$time','$xiadanren','$zt','$total)", $conn); /执行 添加 语句 
header("location:cash register.php?dingdanhao=$dingdanhao"): // 页 面 重 定向 
?> 


(3) 订单 数据 添加 成 功 后 ， 重 定向 到 cash_register.php 页 面 。 在 该 页 面 中 ， 首 先 判 断 
订单 号 变量 是 否 被 设置 ， 如 果 订 单 号 被 设置 ， 则 通过 JavaScript 脚本 中 的 open0 方 法 打开 
showdd.php 文件 ， 输 出 生成 的 订单 详细 信息 。cash_registerphp 页 面 中 的 关键 代码 如 下 : 


<2php 
iflisset($_GET["dingdanhao"]){ // 判 断 订单 号 是 否 被 设置 
$dd=$_GET["dingdanhao"]; // 获 取 订 单 号 
$array=explode("(@",$_SESSION["producelist"]); 。// 读 取 购 物 车 中 数据 
$sum=count($array)*20+260; 


echo" <script language='javascript>"; /通过 JavaScript 脚本 中 的 方法 打开 showdd.php 文 
件 ， 输 出 订单 信息 
echo" 
window.open('showdd.php?dd='+".$dd.",'newframe','top=150,left=200,width=600,height=".$sum.",menubar=n 
0,toolbar=no,location=no,scrollbars=no,status=no )"; 
echo "</script>"; 


} 
?> 
(4) 创建 showdd.php 文件 ， 并 输出 商品 订单 的 详细 信息 。 
技术 要 点 


本 实例 中 ， 订 单 号 的 生成 应 用 的 是 date0 函 数 ， 以 “YmjHis” 格 式 获取 当前 的 时 间作 
为 订单 号 。 

在 生成 订单 之 后 ， 要 清空 购物 车 中 数据 ， 即 为 S SESSION["producelist] 和 $_SESSION 
["quatity"] 赋 空 值 。 
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本 章 读者 可 以 学 到 如 下 实例 : 


Ld 
Lad 
ed 
ed 
Lad 
Lad 
ad 
ed 


党 兆 兆 汰 治 


闪 将 将 


例 165 
例 166 
例 167 
例 168 
例 169 
例 170 
例 171 
例 172 


获取 不 同 地 区 的 当前 时 间 
计算 考试 时 间 

输出 中 文 格式 的 日 期 和 时 间 
检验 日 期 和 时 间 的 有 效 性 
倒计时 

判断 时 间 的 早晚 

网 页 闹钟 
计算 程序 的 运行 时 间 


需 
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实例 165 获取 不 同 地 区 的 当前 时 间 


( 实例 位 置 : 配套 资源 \SL\09\165 ) 


实例 说 明 
系统 的 当前 时 间 受 时 区 限制 。 默 认 情况 下， 系统 的 当前 时 间 是 格林 威 治 时 间 。 用 户 正 | 
确 取得 所 在 的 本 地 时 间 是 很 重要 的 。 本 实例 通过 date0 函 数 获取 不 同 地 区 的 当前 时 间 ， 运 | 


行 结果 如 图 9.1 所 示 。 
真 相 “地 区 时 间 
6:48:23 11:47:22 


图 9.1 获取 不 同 地 区 的 当前 时 间 


现 过 程 

新 建 mdex.php 文件 ， 当 单 击 “地 区 时 间 ” 按 钮 时 ， 首 先 为 当前 PHP 服务 时 间 设 置 时 
区 ， 并 通过 switch 语句 根据 地 址 栏 传 递 参数 的 不 同 ， 通 过 date0O) 函 数 获取 不 同 国家 地 区 的 | 
时 间 ， 其 代码 如 下 : | 


<2php 
这 $_ POST[sub DJ){ // 通 过 POST 方式 传 参 

date_default_timezone set("Asia/ShangHai"): // 设 置 时 区 

switch($_POST['select ]){ /| 条件 语句 
case "中 国 "; // 如 果 是 中 国 
echo date("H:i:s"); /| 输出 时 间 
break: // 结 束 语句 
case "英国 "; // 如 果 是 英国 
echo (date("H")-8).":".date("i:s"): // 输 出 时 间 
break: /结束 语句 
case "日 本 "; // 如 果 是 日 本 
echo(date("H")+1).":".date("i:s"): // 输 出 时 间 
break: // 结 束 语 句 
case "开罗 "; /如 果 是 开罗 
echo(date("H")-6).":".date("i:s"): // 输 出 时 间 
break: // 结 束 语句 
case "莫斯科 "; /如 果 是 莫斯科 
echo(date("H")-5).":".date("i:s"): // 输 出 时 间 
break: // 结 束 语句 
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因为 在 PHP 语言 中 ， 日 期 、 时 间 函 数 依赖 于 服务 器 的 地 区 设置 ， 而 PHP 默认 设置 的 | 


! 
人 


国生 
Note 
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| 名 
| 是 标准 的 格林 威 治 时 间 〈 即 采用 的 是 零 时 区 )， 所 以 如 果 没 有 对 PHP 的 时 区 进行 设置 ， 那 
| 么 当前 使 用 日 期 、 时 间 函 数 获取 的 将 是 英国 伦敦 本 地 时 间 ( 即 零 时 区 的 时 间 )。 
| 这 也 就 是 我 们 为 什么 要 对 PHP 的 时 区 进行 设置 的 原因 , 如 果 不 设置 正确 的 时 区 , 那么 
| PHP 的 日 期 、 时 间 函 数 就 获取 不 到 正确 的 当地 时 间 。 以 东 八 区 为 例 ， 我 们 当地 使 用 的 是 北 
| 京 时 间 ， 如 果 没 有 对 PHP 的 时 区 进行 设置 ， 那 么 获取 的 时 间 就 将 比 当地 的 北京 时 间 少 8 
个 小 时 。 


更 改 PHP 语言 中 的 时 区 设置 有 两 种 方法 : rp Ey 
(1) 在 phpini 文件 中 ， 定 位 到 [date] 下 的 [eee we eerot cinezome wee w me 到 
| “:datetimezone =” 选 项 ， 去 掉 前 面 的 分 号 ， 并 设置 hetps/ /bhp net/date .tinezone 
| 它 的 值 为 当地 所 在 时 区 使 用 的 时 间 。 修 改 内 容 如 图 92 9 这 证 
| 所 示 。 


例如 ， 如果 当地 所 在 时 区 为 东 八 区 ， 那么 就 可 以 设置 “date.timezone =” 的 值 为 : PRC、 
| Asia/Hong Kong、Asia/Shanghai (上海 ) 或 者 Asia/Urumqi (乌鲁木齐 ) 等 。 这些 都 是 东 八 
| 区 的 时 间 。 
设置 完成 后 ， 保 存 文件 ， 重 新 启动 Apache 服务 器 。 
(2) 在 应 用 程序 中 ,在 日 期 、 时 间 函 数 之 前 使 用 date_default_timezone_set0) 函 数 就 可 
| 以 完成 对 时 区 的 设置 。date_default_timezone_set() 函 数 的 语法 如 下 : 
| date_default_timezone set(timezone):; 
| 参数 timezone 为 PHP 可 识别 的 时 区 名 称 ， 如 果 时 区 名 称 PHP 无 法 识别 ， 则 系统 采用 
| UTC 时 区 。 
例如 ， 设 置 北京 时 间 可 以 使 用 的 时 区 包括 : PRC (中 华人 民 共 和 国 )、Asia/Chongqing 
(重庆 )，Asia/Shanghai (上 海 ) 或 者 Asia/Urumgqi (乌鲁木齐 )。 这 几 个 时 区 名 称 是 等 效 的 。 


实例 166 计算 考试 时 间 


( 实例 位 置 : 配套 资源 \SL\09\166 ) 


| 实例 说 明 


计算 考试 时 间 程 序 是 一 种 单纯 的 将 两 个 时 间 点 的 时 间 惟 


| 做 算术 运算 。 本 实例 通过 time0 函 数 实现 考试 时 间 的 计算 ， 运 AS 


| 行 结果 如 图 9.3 所 示 。 您 用 时 5 秒 管 起 
| 实现 过 程 图 93 计算 考试 时 间 


| (1) 创建 PHP 脚本 文件 。 首 先 编号 <fomm> 表 单 并 设置 两 个 提交 按钮 ， 当 每 个 按钮 被 
| 单 击 后， 利用 SESSION 变量 保存 此 时 刻 的 时 间 蕉 ， 并 进行 求 差 运算 ， 然 后 输出 结果 。 其 
| 代码 如 下 : 
| < 


session start():; 
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header("Content-type:text/html; charset=utf-8"); 

echo "<form action =" method ='post>"; // 输 出 表单 

echo "<input type = 'submit name='sub' value=' 开 始 答题 >&nbsp;<input type='submit name= 
'sub_l'value = 答题 完毕 >"; 

echo "</form>"; 


if($_POST['sub']){ // 通 过 POST 方式 传 参 
Ori /取得 当前 时 间 戳 
$_SESSION['time'] = $time; /将 时 间 戳 保存 在 SESSION 中 
echo "<script>alert( 单 击 确定 开始 答题 ;</script>"; /| 输出 提示 | 
} | 
这 $_ POST[sub 1D){ // 通 过 POST 方式 传 参 | 
iflisset($_ SESSION[Ytime])){ // 判 断 SESSION 是 否 存在 | 
echo "您 用 时 ".(time0-$_SESSION['time])." 秒 答题 "， /输出 结果 | 
session_destroy(); /销毁 SESSION | 
j}elsef /否则 输出 提示 | 
echo "<script>alert( 您 还 没有 答题 无 法 结束 , 请 先 答题 !");location.href='index.php'</script>";， | 
} | 
} | 
> 


(2) 将 文件 存储 于 \MR\09\002\ 文 件 夹 下 ， 并 命名 为 mdexphp。 运 行 结果 如 图 9.3 所 示 。 
技术 要 点 


本 实例 的 关键 点 是 time0 函 数 的 灵活 运用 。 当 单 击 “ 开 始 答题 ”按钮 时 ， 将 time0 函 
数 获取 的 时 间 蕉 存储 到 SESSION 变量 中 ， 当 单 击 “答题 完毕 ” 按钮 时 ， 再 次 通过 time() 
函数 获取 系统 的 当前 时 间 戳 。 通 过 当前 时 间 戳 减 去 开始 定义 的 时 间 瀹 , 就 是 考试 所 用 时 间 。 


实例 167 输出 中 文 格式 的 日 期 和 时 间 


( 实例 位 置 : 配套 资源 \SL\09\167 视频 位 置 : 配套 资源 \SP\09\167 ) ! 


实 例 说 明 EETZZTODODTETTTORDLEG3 
| 立 隆 中。 绵 缉 人 ) 查看 NO 收 六 | ow | ! 
本 实例 使 用 date0 函 数 实现 中 文 格式 的 日 期 和 时 A 
间 的 输出 ， 其 运行 效果 如 图 9.4 所 示 。 2011 年 06 月 3 日 13 时 15 分 Oe 种 =: | 
实现 过 程 I | 
0 a 图 94 输出 中 文 格式 的 日 期 和 时 间 | 
本 实例 采用 的 是 date0 函 数 ， 定 义 传递 到 此 函数 | 


的 参数 为 “Y 年 m 月 d 日 H 时 i 分 m 秒 ”。 其 代码 如 下 : 


<?php 
header("Content-Type:text/html:charset=utf-8"): // 设 置 编 码 集 | 
date_default timezone set("Asia/Shanghai"): // 设 置 时 区 | 
echo date("Y 年 m 月 d 日 卫 时 i 分 到 秒 "); /输出 信息 | 
> | 
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技术 要 点 


| 本 实例 先 使 用 date_default_timezone_set0 函 数 设 置 时 区 , 然后 使 用 date0 函 数 获取 时 间 


实例 168 ”检验 日 期 和 时 间 的 有 效 性 


( 实例 位 置 : 配套 资源 \SL\09\168 ) 


”实例 说 明 
| 一 年 有 12 个 月 、 一 个 月 有 31 天 (或 30 天 ， 
| 2 月 有 28 天 ， 间 年 为 29 天 )， 一 星期 有 7 天 …… 
| 这 些 都 是 基本 常识 。 但 计算 机 并 不 能 自己 分 辩 数 
| 据 的 对 与 错 ， 只 是 依靠 开发 者 提供 的 功能 去 执行 
| 或 检查 。 在 PHP 中 ， 通 过 checkdateO 函 数 可 以 检 
| 验 日 期 和 时 间 的 有 效 性 。 运 行 本 实例 ， 效 果 如 
| 图 95 所 示 。 图 95 检验 日 期 和 时 间 的 有 效 性 
| 实现 过 程 
| 具体 步骤 如 下 ; 

(1) 创建 index.php 文件 ， 通 过 form 表单 提交 数据 信息 ， 以 及 数据 录入 时 间 。 
| (2) 创建 index_ok.php 文件 ， 获 取 表 单 提交 的 数据 ， 完 成 对 提交 日 期 格式 的 验证 。 
| 其 关键 代码 如 下 : 


<?php 
header("Content-type:text/html:charset=utf-8"):; /设置 页 面 编码 格式 
iffisset($_POST['Submit])){ /获取 提交 的 日 期 数据 


这 checkdate($_ POST[month'].$_ POST['day].$_ POST[year])){ /验证 日 期 格式 是 否 正确 
echo "提交 日 期 合法 !1"; 
}else{ 
echo "<script> alert(' 您 输入 的 日 期 不 合法 !!"); history.back0;</script>"; 
} 
} 


| ?> 
| 本 实例 主要 使 用 checkdate0 函 数 传递 三 个 参数 判断 某 年 某 月 是 否 存 在 某 日 的 操作 。 
| checkdate0 函 数 验证 日 期 的 有 效 性 ， 如 果 日 期 有 效 则 返回 rue， 否 则 返回 false。 其 语 
| 法 如 下 : 
| bool checkdate ( int month, int day, int year) 
checkdate() 函 数 的 参数 说 明 如 表 9.1 所 示 。 
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表 9.1 checkdate() 函 数 的 参数 说 明 


参数 说 ”了 明 
month | month 的 有 效 值 是 从 1 一 12 
da day 的 有 效 值 在 给 定 的 month 所 应 该 具有 的 天 数 范围 之 内 ， 包 括 半年 
year year 的 有 效 值 是 从 1 一 32767 
实例 169 ”倒计时 
( 实 便 位置 : 配套 资源 \SL\09\169 视频 位 置 : 配套 资源 \SP\09\169 ) 
实例 说 明 
倒计时 是 人 们 在 生活 中 经 常会 用 到 的 一 | err 
个 功能 ， 例 如 ，2010 年 上 海 世博 会 的 倒计时 、 DT CIE GE 


突 WB 条 2012F 元 BEN 本 序 全- 四 "中 ” 


2012 年 看 节 的 倒计时 等 。 本 实例 应 用 PHP 的 a 
日 期 、 时 间 函 数 为 2012 年 元 旦 设计 一 个 合计。 | 距离 2012 年 元 旦 还 有 170 天 由 


这 _ [G6 @ inemet | fF 扩 楼 式 要 用 区 
时 程序 ， 如 图 9.6 所 示 。 


图 9.6 倒计时 
实现 过 程 
创建 index.php 文件 ， 编 写实 现代 码 ， 具 体内 容 如 下 : 
<?php 
$timel = strtotime(date( "Y-m-d")); // 当 前 的 系统 时 间 
$time2 = strtotime("2012-1-1"); /2012 年 元 旦 
$sub2 = ceil(($time2 - $timel) / 86400); 11(60 秒 *60 分 *24 小 时 ) 秒 /天 
echo "距离 2012 年 元 旦 还 有 <font color=red>$sub2 </font> 天 !1"; 
?> 
技术 要 点 


倒计时 的 原理 非常 简单 ， 就 是 用 一 个 固定 的 时 间 减 去 当前 的 时 间 ， 所 得 到 的 就 是 剩余 
时 间 。 要 完成 时 间 的 加 减 操作 ， 同 比较 大 小 类 似 ， 都 要 将 时 间 转 换 成 时 间 戳 ， 然 后 才能 计 | 
算 ， 最 后 再 将 时 间 戳 转换 成 日 期 输出 。 

实例 170 判断 时 间 的 早晚 


( 实例 位 置 : 配套 资源 \SL\09\170 视频 位 置 : 配套 资源 \SP\09\170 ) 


实例 说 明 


在 PHP 语言 中 ， 要 完成 对 两 个 时 间 早晚 的 比较 ， 必 须 先 将 时 间 转 换 为 时 间 蕉 ， 然 后 | 
才 可 以 进行 比较 。 而 将 时 间 转 换 为 时 间 蕉 可 以 通过 strtotime0 函 数 来 完成 。 其 运行 效果 如 | 
图 9.7 所 示 。 | 
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时 间 ，2010 年 10 月 10 日 10 时 10 分 10 秒 


早 于 2011-11-11 111111 


ER 


图 9.7 判断 时 间 的 早晚 

| 实现 过 程 

首先 定义 两 个 固定 的 时 间 ， 然 后 通过 strtotime0 函 数 将 固定 时 间 转 换 成 时 间 稚 ， 最 后 
| 对 两 个 时 间 戳 的 值 进行 比较 。 其 代码 如 下 : 


<2php 
$time="2010 年 10 月 10 日 10 时 10 分 10 秒 "; // 设 置 固 定时 间 


Stimes = "2011-11-11 11:11:11"; // 设 置 固定 时 间 
if(strtotime($time) - strtotime($times) < 0){ // 对 两 个 时 间 进 行 运算 
echo "时 间 : ".$time."<p> 早 于 ".$times ; //time - times<0 说 明 time 的 时 间 在 前 
jelse{ 
echo "时 间 : ".$times."<p> 早 于 ".$time; /和 否则， 说 明 times 的 时 间 在 前 
} 
| > 
| 技术 要 点 


PHP 中 应 用 strtotime0 函 数 将 任何 英文 文本 的 日 期 解析 为 UNIX 时 间 戳 ， 其 值 为 相对 
于 now 参数 给 出 的 时 间 ， 如 果 没 有 提供 此 参数 ， 则 用 系统 当前 时 间 ， 此 时 与 实例 142 中 的 
time0) 函 数 相同 。strtotime0 函 数 的 语法 如 下 : 


int strtotime ( string time [, int now] ); 


该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ; 如 果 
参数 time 的 格式 是 相对 时 间 , 其 对 应 的 时 间 就 是 参数 now 来 提供 的 , 当 没 有 提供 参数 now 
时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 失 败 ， 则 返回 false。 在 PHP5.1.0 之 前 的 版 本 中 ， 
本 函数 在 失败 时 返回 -1。 


实例 171 网 页 阅 钟 


( 实例 位 置 配套 资源 \SL\09\171 ) 


实例 说 明 
| 闵 钟 是 生活 中 经 常 使 用 的 一 个 小 工具 , 它 会 在 指定 时 间 叫 你 起 床 。 在 Web 程序 中 也 可 
| 以 应 用 这 个 原理 ， 开 发 一 个 “网 页 曾 钟 ” 提示 用 户 在 指定 的 时 间或 者 时 间 段 内 要 做 什么 
| 工作 。 下 面 编写 一 个 实例 ， 当 系统 的 当前 时 间 运 行 到 9 月 18 日 ， 给 出 提示 信息 “ 勿 访 国 
| 耻 !”， 其 运行 效果 如 图 9.8 所 示 。 
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图 9.8 网 页 闹钟 


实现 过 程 Ez 
所 请 网 页 曾 钟 也 就 是 一 个 日 志 提醒 功能 ， 通 过 判断 系统 中 当前 的 时 间 与 指定 的 某 个 时 | 

间或 者 时 间 段 是 否 相同 ， 如 果 相同 ， 系 统 就 给 出 一 个 对 应 的 提示 信息 ， 提 示 用 户 该 做 什么 | 

(例如 ， 每 天 工作 记录 的 上 传 、 每 月 经 验 技巧 的 提交 或 者 员工 生日 的 提醒 等 )， 都 可 以 通 | 

过 日 志 的 形式 进行 提醒 。 在 本 实例 中 ， 通 过 当前 时 间 蕉 与 9 月 18 日 的 时 间 崔 进行 比较 ， | 

如 果 相 同 ， 则 给 出 提示 信息 。 其 关键 代码 如 下 : 


<2php 
$timel = strtotime(date("Y-m-d")); /当前 的 系统 时 间 ， 获 取 月 和 天 的 时 间 戳 
$time2 = strtotime(date("Y")."-09-18"); // 设 置 时间 9 月 18 日 的 时 间 戳 
if($timel—$time2){ // 判 断 两 个 时 间 惟 是 否 相同 
echo "<script>alert( 勿 忘 国耻 ! ');window.location.hre 人 ='index.php';</script>"; /给 出 提示 信息 
Jelse{ 
echo "今天 不 是 一 个 特殊 的 日 子 ! "; 
} 
?> 
技术 要 点 


本 实例 主要 使 用 strtotime0 函 数 ，PHP 中 应 用 strtotime0O 函 数 将 任何 英文 文本 的 日 期 解 | 

析 为 UNIX 时 间 惟 ,其 值 为 相对 于 now 参数 给 出 的 时 间 ， 如 果 没 有 提供 此 参数 则 用 系统 当 | 

前 时 间 。strtotime 函数 的 语法 如 下 : | 

int strtotime ( string time [, int now] ); | 

该 函数 有 两 个 参数 。 如 果 参 数 time 的 格式 是 绝对 时 间 ， 则 now 参数 不 起 作用 ， 如 果 | 

参数 time 的 格式 是 相对 时 间 , 其 对 应 的 时 间 就 是 参数 now 来 提供 的 , 当 没有 提供 参数 now | 
时 ， 对 应 的 时 间 就 为 当前 时 间 。 如 果 解 析 失 败 ， 则 返回 false。 在 PHP5.1.0 之 前 的 版 本 中 ， 

本 函数 在 失败 时 返回 -1 。 | 


实例 172 计算 程序 的 运行 时 间 
( 实例 位 置 配套 资源 \SL\09\172 视频 位 置 配套 资源 \SP\09\172 ) 


实例 说 明 


在 百度 中 ， 当 我 们 执行 一 个 查询 操作 时 ， 在 获取 到 查询 结果 后 ， 页 面 中 就 会 出 现行 | 
文字 ， 提 示 根 据 关键 字 搜 索 到 多 少 个 结果 ， 以 及 搜索 所 用 的 时 间 。 这 个 时 间 就 是 程序 在 执 | 
行 这 个 搜索 时 所 用 的 时 间 ， 那 么 它 是 如 何 实现 的 呢 ? 本 实例 模仿 它 来 计算 程序 运行 的 时 | 
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间 。 运 行 结果 如 图 9.9 所 示 。 


着 计算 皇 记 的 正厅 j 癌 - WindowsIntemes Explorer [Enel = 
OO e/a [Sa 5 
祝 HR | EEC 


70 天 岂 


| 图 9.9 计算 程序 的 运行 时 间 

| 实现 过 程 

| 首先， 在 执行 查询 操作 之 前 定义 一 个 时 间 ， 将 其 精确 到 微 秒 。 然 后 ， 执 行 查询 操作 ， 
| 并 在 查询 功能 执行 完毕 后 再 次 获取 一 个 时 间 ， 同 样 精确 到 微 秒 。 最 后 ， 应 用 后 获取 的 时 间 
， 减 去 最 初 获 取 的 时 间 ， 就 是 本 次 查询 所 用 的 时 间 。 其 关键 代码 如 下 : 

| <2php 


必 声明 run_time 函数 */ 
function run_timeO{ 


list($msec, $sec) = explode(" ", microtime()); // 使 用 explode 函数 返回 两 个 变量 
Ietum ((floab$msec + (float)$sec): /返回 两 个 变量 的 和 
} 
$start_time = run_time(); // 第 一 次 运行 run_time0 函 数 
率 ”运行 PHP 代 码 段 ”*/ 
$end_ time = run_time(); // 再 次 运行 ran_time0 函 数 
| 和 
| 技术 要 点 


本 实例 主要 通过 microtimeO 获 取 当 前 时 间 的 微 秒 数 和 时 间 戳 。 
| microtime() 函 数 , 返回 当前 UNIX 时 间 戳 和 微 秒 数 , 返回 格式 为 “msec sec” 的 字符 串 ， 
| 其 中 sec 是 当前 的 UNIX 时 间 戳 ,msec 是 微 秒 数 。 本 函数 仅 在 支持 gettimeofday0O 函 数 的 操 
| 作 系统 下 可 用 ， 其 语法 如 下 : 


string microtime ( void ) 


| 应 用 explode() 函 数 将 microtime() 函 数 返回 的 字符 串 进行 分 隔 ， 返 回 一 个 数组 ， 包 括 两 
| 个 元 素 : 一 个 元 素 是 当前 时 间 的 微 秒 数 ， 另 一 个 是 当前 时 间 的 时 间 怜 。 应 用 listO 函 数 将 
| explode0 函 数 返 回 的 数组 值 赋 给 指定 的 变量 。 最 后 ， 获 取 两 个 变量 值 的 和 。 
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本 章 读者 可 以 学 到 如 下 实例 : 
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GD2 函数 填充 几何 图 形 

GD2 函数 在 照片 上 添加 文字 

GD2 函数 为 图 片 添加 文字 水 印 

GD2 函数 为 图 片 添加 图 像 水 印 

GD2 函数 生成 图 形 验证 码 

折线 图 分 析 2010 年 的 销售 额 

柱 形 图 分 析 编 程 词典 销售 比例 

饼 形 图 分 析 2010 年 图 书 销量 

GD2 函数 折线 图 分 析 网 站 月 访问 量 走势 
GD2 函数 柱状 图 分 析 编 程 词典 满意 度 调 查 
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折线 图 分 析 2010 年 牛肉 市 场 价格 走势 
多 饼 形 图 区 块 分 析 2010 年 图 书 销量 

缩 略 图 艺术 库 

通过 图 像 显示 投票 统计 结果 

通过 图 像 显示 密码 安全 强度 

任意 调整 上 传 图 片 的 大 小 


需 


a 
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使 用 GD2 函数 不 仅 可 以 绘制 线条 图 形 ， 而 且 可 以 绘 
制 填充 图 形 ， 如 填充 圆 形 、 填 充 矩 形 等 。 在 本 实例 中 ， 
将 介绍 圆 形 和 和 拢 形 的 填充 ， 其 运行 结果 如 图 10.1 所 示 。 
实现 过 程 
本 实例 应 用 GD2 函数 绘制 填充 圆 形 和 填充 矩形 ， 其 
代码 如 下 : 
<?php 
header("Content-type: image/png"); 
S$img = imagecreate(400, 200); 
$bg = imagecolorallocate($img, 0, 0, 255); 
$white = imagecolorallocate($img, 255, 0, 255); 
imagefilledellipse($img, 100, 100, 150, 150, $white); 
imagefilledrectangle($img, 200, 50, 300, 150, $white); 
imagepng($img); 
imagedestroy($img); 
?> 


技术 要 点 


实例 173 ”GD2 函数 填充 几何 图 形 
( 实例 位 置 : 配套 资源 \SL\10\173 视频 位 置 配套 资源 \SP\10\173 ) 
， 实 例 说 明 


图 10.1 GD2 函数 填充 几何 图 形 


/将 图 像 输出 到 浏览 器 
// 创 建 一 个 400X200 的 图 像 


/绘制 圆 形 
/绘制 矩形 


在 GD2 函数 库 中 ， 应 用 imagefill0 函 数 实现 图 像 的 填充 操作 ， 其 语法 如 下 : 


bool imagefill ( resource image, int x, int y, int color) 


imagefill() 函 数 在 image 图 像 的 坐标 x,y (图 像 左 上 角 为 0.0) 处 用 color 颜色 执行 区 域 


填充 〈 即 与 x,y 点 颜色 相同 且 相 邻 的 点 都 会 被 填充 )。 


imagefilledarc0 函 数 绘 制 一 个 椭圆 弧 线 ， 其 语法 如 下 : 


bool imagefilledarc ( resource image, int cx, int ¢y, int w, int h, int s, int e, int color, int style ) 


imagefilledarc() 函 数 在 image 所 代表 的 图 像 中 以 cx, cy (图 像 左上 角 为 0.0) 为 坐标 点 
绘制 一 顶 圆 弧 。 如 果 成 功 ， 则 返回 tue; 和 否则， 返回 false。w 和 分别 指 定 椭 圆 的 宽 和 高 ， 
s 和 e 参数 以 角度 指定 起 始 和 结束 点 。style 可 以 是 下 列 值 按 位 或 (OR) 后 的 值 : 


(1) IMG ARC PIE. 

(2) IMG ARC CHORD. 
(3) IMG ARC NOFILL。 
(3) IMG ARC EDGED. 


IMG ARC PIE 和 IMG ARC CHORD 是 互 斥 的 。IMG ARC CHORD 只 是 用 直线 连 


<“ 2958 
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接 起 始 和 结束 点 ，IMG_ARC _PIE 则 产生 圆 形 边界 (如 果 两 个 都 用 ，IMG _ARC _CHORD 
生效 )。IMG_ARC_NOFILL 指明 弧 或 弦 只 有 轮廓 ， 不 填充 。IMG_ARC_EDGED 指明 用 直 | | 


线 将 起 始 和 结束 点 与 中 心 点 相连 , 和 IMG ARC _NOFILL 一 起 使 用 是 绘制 便 状 图 轮 亡 的 好 


方法 (而 不 用 填充 )。 
Imagefilledellipse0) 函 数 绘制 一 个 椭圆 ， 其 语法 如 下 : 
bool imagefilledellipse ( resource image, int cx, int ¢y, int w, int h, int color ) 
该 函数 在 image 所 代表 的 图 像 中 以 cx, cy (图 像 左 上 角 为 0.0) 为 中 心 绘制 一 


w 和 分别 指定 椭圆 的 宽 和 高 , 使 用 color 颜色 填充 。 如果 成 功 则 返回 true, 否则 返回 false。 


指点 迷津 : 


在 通过 GD2 函数 库 创 建 图 像 时 ，imagedestroy() 函 数 是 必 不 可 少 的 ， 通 过 它 可 以 销毁 
指定 的 图 像 ， 释 放 与 image 关联 的 内 存 。 如 果 不 应 用 该 函数 ， 那 么 与 image 关联 的 数据 会 


一 直 存储 在 内 存 中 。 


实例 174 GD2 函数 在 照片 上 添加 文字 


( 实例 位 置 : 配套 资源 \SL\10\174 视频 位 置 配套 资源 \SP\10\174 ) 


说 


个 李 


| 


PHP 中 的 GD 库 支 持 中 文 ， 但 必须 要 以 UTF-8 格式 的 参数 来 进行 传递 。 如 果 使 用 


imageStringO 函 数 直接 绘制 中 文字 符 串 ， 就 会 显示 乱码 ， 这 是 因为 GD2 对 中 文 只 能 接收 
UTF-8 编码 格式 ， 并 且 默 认 使 用 了 英文 的 字体 ， 所 以 要 输出 中 文字 符 串 ， 就 必须 对 中 文字 
符 串 进行 转 码 ， 并 设置 中 文字 符 使 用 的 字体 ; 否则， 输出 的 只 能 是 乱码 。 在 本 实例 中 ， 实 
现 GD2 函数 输出 中 文字 符 串 ， 并 且 通 过 GD2 函数 将 中 文字 符 串 在 照片 上 输出 ， 其 运行 结 


果 如 图 10.2 所 示 。 


图 10.2 在 照片 上 添加 文字 


实现 过 程 


本 实例 应 用 imagecreatefromjpeg0 和 imagettftext0 函 数 在 照片 上 添加 中 文字 符 串 。 其 代 
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人 码 如 下 : 
<?php 
header("content-type:image/jipeg"); // 定 义 输出 为 图 像 类 型 
Sim=imagecreatefromipeg("images/P1020494.JPG"); // 载 入 照片 
$textcolor=imagecolorallocate($im,25,25,136); // 设 置 字体 颜色 为 蓝 色 ， 值 为 RGB 颜色 值 
S$font="Font/mzd .ttf"; // 定 义 字 体 
$to=" 落 起 与 孤 鸽 齐 飞 "; 
imagettftext($im,80,0,200,200, $textcolor, $font, $to); // 写 TTF 文字 到 图 中 
$to=" 秋 水 共 长 天 一 色 "; 
imagettftext($im,80,0,300,400, $textcolor, $font, $to); // 写 TTF 文字 到 图 中 
imagejpeg($im); // 建 立 了 PEG 图 形 
imagedestroy($im); // 结 束 图 形 ， 释 放 内 存 空间 
?> 

多 学 两 招 ; 


因为 本 实例 中 页 面 使 用 的 是 UTF-8 编码 格式 , 所 以 在 定义 向 图 片 中 添加 的 中 文字 符 串 
时 可 以 直接 使 用 ， 不 需要 编码 格式 的 转换 。 但 是 ， 如 果 页 面 本 身 使 用 的 是 GB2312 编码 格 
式 ， 那 么 就 必须 应 用 iconvO 函 数 对 向 图 片 中 添加 的 中 文字 符 串 进行 编码 格式 的 转换 ， 由 
GB2312 编码 转换 为 UTF-8 编码 。 
技术 要 点 

在 PHP 中 向 图 像 中 添加 中 文字 符 串 应 用 的 是 imagettftext0 函 数 ， 其 语法 如 下 : 


array imagettftext ( resource image, float size, float angle, int x, int y, int color, string fontfile, string 
text ) 


imagettftext 0 函数 的 参数 说 明 如 表 10.1 所 示 。 
表 10.1 imagettftext() 函 数 的 参数 说 明 


参数 说 了 明 
image 图 像 资源 
size 字体 大 小 。 根 据 GD 版 本 不 同 ， 应 该 以 像素 大 小 指定 “GD1) 或 点 大 小 (GD2) 


字体 的 角度 ， 顺 时 针 计算 ，0” 为 水 平 ， 也 就 是 3 点 钟 的 方向 (由 左 到 右 ) ，90” 则 


ee 为 由 下 到 上 的 文字 

文字 的 x 举 标 值 。 设 定 第 个 字符 的 基本 点 

文字 的 y 坐标 值 。 设 定 字体 基线 的 位 置 ， 不 是 字符 的 最 底 端 
color 文字 的 颜色 

fontfile 。 | 字体 的 文件 名 称 ， 也 可 以 是 远 端的 文件 

text 字符 串 内 容 


在 PHP 中 ,通过 GD2 函数 对 卫 G 格式 的 照片 进行 操作 ,应 用 的 是 imagecreatefromjpegO 
函数 ， 从 JPEG 文件 或 URL 新 建 一 图 像 。 其 语法 如 下 : 
resource imagecreatefromjpeg ( string filename ) 
参数 flename 可 以 是 本 地 文件 , 也 可 以 是 网 络 的 URL 地 址 。 返回 值 为 JPEG 的 文件 代 
"260 
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码 ， 可 供 其 他 函数 使 用 。 该 函数 在 失败 时 返回 一 个 空 字符 串 ， 并 且 输 出 一 条 错误 信息 。 


实例 175 GD2 函数 为 图 片 添加 文字 水 印 


( 实例 位 置 : 配套 资源 \SL\10\175 ) 


实例 说 明 


图 片 是 Web 页 面 最 为 重要 的 组 成 元 素 之 一 , 新 闻 网 站 、 图 片 资料 网 站 等 备 受 网 民 关 注 | 
的 网 站 每 天 都 会 上 传 大 量 的 图 片 。 如 果 直 接 将 图 片上 传 到 页 面 中 ， 很 可 能 被 浏览 者 保存 使 | 
用 , 这 样 站 点 的 版 权 就 不 能 得 到 很 好 | 
的 保证 。 如 果 在 上 传 图 片 过 程 中 , 动 
态 地 为 图 片 添 加 水 印 效果 , 这 样 不 仅 
可 保护 版 权 , 如 果 设 计 合理 还 能 有 助 
于 网 站 的 推广 。 在 本 实例 中 , 将 讲解 
如 何在 上 传 图 片 的 过 程 中 为 图 片 深 


加 水 印 文 字 ， 其 运行 结果 如 图 10.3 
所 示 。 图 10.3 为 图 片 添 加 文字 水 印 


商品 名 称 : 。 PHP 开 发 并 型 模 块 大 全 
商品 分 类 :图书 -程序 开发 
市 场 价格 ;> 加 


会 员 价格 : 人 60 00 
商品 颜色 : 至 色 
商品 库存 : 本 


Sr i 


实现 过 程 
具体 步骤 如 下 : 

(1) 创建 mdex.php 文件 。 首 先 ， 创 建 一 个 表单 ， 完 成 上 传 图 片 的 提交 操作 。 然 后 ， | 
在 本 页 中 输出 存储 在 服务 器 指定 文件 夹 下 的 图 片 。 最 后 ， 获 取 表单 中 提交 的 图 片 数据 ， 应 | 
用 move uploaded file0 函 数 完成 图 片 的 上 传 操 作 ， 并 且 实 例 化 存储 在 AddWaterPress.php | 
文件 中 的 AddWaterPress 类 , 调用 add0 方 法 为 指定 的 图 片 添加 文字 水 印 。 其 关键 代码 如 下 : | 
if(move_uploaded file($_FILES["file"]["tmp_name"], $saveDir)){ ”// 执 行文 件 上 传 操作 | 

require_once 'AddWaterPress.php': // 包 含 添加 水 印 操作 的 文件 
$addWaterPress = new AddWaterPress(): /类 的 实例 化 | 
$addWaterPress->add($saveDir, "吉林 省 明日 科技 ");// 执 行 添加 方法 ， 传 递 参数 ， 指 定 水 印 文字 | 
echo "<script>alert( 图 片 添加 成 功 ):</script>"; | 


} | 
(2) 创建 AddWaterPress.php 文件 ， 编 写 AddWaterPress 类 的 内 容 。 其 关键 代码 如 下 : 
<?php 
class AddWaterPress{ /定义 类 文件 
/省 略 了 部 分 代码 
function add($imageUa, $SwatherImageUrD{ /定义 添加 方法 | 
$img = (@$this->getImageRes($this->getExtendsName($imageUrl), $imageUrD; /获取 被 操作 的 图 | 
像 标识 | 
Stextcolor=imagecolorallocate($img,190.,1,23); // 设 置 字体 颜色 为 蓝 色 ， 
值 为 RGB 颜色 值 
S$font="Font/FZHCJW.TTF": /定义 字体 


imagettftext($img,15,56,20,130,$textcolor, $font,$watherImageUrl); // 写 TTF 文字 到 图 中 
. 261 . 人 
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/根据 图 像 标识 符 、 后 绥 和 路 径 ， 执 行 outputImage 方法 ， 输 出 图 像 
S$this->outputImage($img, $this->getExtendsName($imageUrD, $imageUrD: 
imagedestroy($img): 1/ 销毁 图 像 


} 


| 多 学 两 招 : 


本 实例 完成 的 是 中 文字 符 串 水 印 标记 的 添加 操作 ， 如 果 要 添加 英文 字符 串 格式 的 水 印 


| 标记， 那么 就 可 以 直接 使 用 imageString(0) 函 数 来 完成 。 其 方法 与 在 图 像 中 输出 英文 字符 囊 
| 是 相同 的 。 


| 技术 要 点 


上 传 图 片 添加 水 印 的 重点 是 图 像 处 理 函 数 的 运用 ， 至 于 文件 的 上 传 已 经 在 前 面 的 实例 


| 中 进行 了 详细 的 讲解 ， 这 里 就 不 再 獒 述 。 


(1) 创建 图 像 函数 。 
创建 图 像 函 数 的 运用 是 完成 这 个 实例 的 第 一 步 , 因为 需要 根据 上 传 图 片 的 后 级 (格式 》 


运用 不 同 的 函数 来 创建 新 图 像 ， 这 里 定义 3 种 格式 的 图 片 《gif、jpg 和 png)， 所 以 要 应 用 
| 到 3 个 创建 图 像 函数 。 


imagecreatefromgif(): 根据 GIF 文件 或 者 URL 新 建 一 图 像 ， 返 回 图 像 标识 符 。 

imagecreatefromjpeg(): 根据 JPG 文件 或 者 URL 新 建 一 图 像 ， 返 回 图 像 标 识 符 。 

imagecreatefrompng(): 根据 PNG 文件 或 者 URL 新 建 一 图 像 ， 返 回 图 像 标 识 符 。 
(2) 操作 图 像 函 数 。 

新 图 像 创 建成 功 后 将 返回 一 个 图 像 标识 符 ， 操 作 图 像 函 数 根 据 标识 符 对 图 像 进 行 操 


| 作 ， 这 里 应 用 2 个 函数 ， 


imagecolorallocate(): 定义 水 印 文字 的 颜色 。 
imagettftext(): 在 返回 的 图 像 中 输入 中 文字 符 串 。 
(3) 输出 图 像 函数 。 
与 创建 图 像 函数 对 应 ， 同 样 有 3 个 输出 图 像 函数 。 
回 imagegift0): 以 GIF 格式 将 图 像 输出 到 浏览 器 或 文件 。 
回 imagejpeg0: 以 JPG 格式 将 图 像 输出 到 浏览 器 或 文件 。 
回 imagepng0: 以 PNG 格式 将 图 像 输出 到 浏览 器 或 文件 。 
(4) 销毁 图 像 函 数 。 
在 完成 图 像 的 创建 和 输出 之 后 ， 有 必要 销毁 图 像 ， 释 放 与 image 相关 的 内 存 。 此 时 ， 


EE 用 的 是 imagedestroy0 函 数 。 其 语法 如 下 : 


bool imagedestroy ( resource image ) 


imagedestroy0) 函 数 释放 与 image 关联 的 内 存 。 参 数 image 是 由 图 像 创建 函数 返回 的 图 
| 像 标识 符 。 
在 本 实例 中 ， 对 上 述 介绍 的 函数 进行 整合 应 用 ， 创 建 AddWaterPress 类 ， 定 义 


| getExtendsName() 方 法 ， 获 取 上 传 图 片 的 文件 后 级 ; 定义 getImageRes0 方 法 ， 根 据 上 传 文 
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件 的 后 组 创建 新 图 像 ; 定义 outputImage() 方 法 ， 输 出 图 像 ; 定义 add0 方 法 ， 向 指定 的 图 片 
中 添加 文字 水 印 。 | 


实例 176 GD2 函数 为 图 片 添加 图 像 水 印 


( 实例 位 置 : 配套 资源 \SL\10\176 ) 


实例 说 明 | 
实例 175 介绍 的 是 如 何 为 照片 添加 文字 水 印 ， 在 本 实例 中 将 介绍 如 何 为 上 传 图 片 添加 
一 个 图 像 水 印 ， 运 行 结果 如 图 10.4 所 示 。 | 


"WE 
E23 有 


法 看 海 ! 


图 10.4 为 图 片 添加 图 像 水 印 
实现 过 程 | 
本 实例 的 实现 步骤 与 实例 175 相同 ， 唯 一 区 别 是 创建 AddWaterPress.php 文件 ， 编 写 
AddWaterPress 类 的 add(0 方 法 时 , 应 用 的 是 getimagesize0 和 imagecopyO 函 数 完成 图 像 水 印 ， 
的 添加 操作 。Add0 方 法 的 代码 如 下 : | 


function add($imageUrl, $watherImageUrl, $x, $y){ // 定 义 添加 方法 | 
Simg = (@3$this->getImageRes($this->getExtendsName($imageUrl), $imageUrl); /获取 被 添加 的 图 | 


像 标识 
$imsgl = (@S$this->getImageRes($this->getExtendsName($watherImageU1l), SwatherImageUrD); 
S$size = getimagesize($imageUrD; /获取 图 像 大 小 
$sizel = getimagesize($watherImageUrD; // 获 取水 印 图 片 的 大 小 
这 $x 一 null && $y 一 nulD){ // 判 断 参 数 是 否 为 空 
$xl = ($size[0]-$sizel[0])/2;// 根 据 图 像 大 小 数组 中 返回 的 值 ， 计 算 图 像 的 横 坐 标 
$y1= ($size[1]-$sizel[1])/2:// 根 据 图 像 大 小 数组 中 返回 的 值 ， 计 算 图 像 的 纵 坐 标 
jelse{ 
S$xl = $x; /如 果 不 为 室 ， 则 直接 使 用 坐标 数据 
$y1 = $y; // 如 果 不 为 空 ， 则 直接 使 用 坐标 数据 
} | 
imagecopy(Simg, $img1, $x1, $y1, 0, 0, $size1[0], $size1[1]);// 将 imgl 的 一 部 分 复制 到 img 的 | 
指定 位 置 | 
// 根 据 图 像 标识 符 、 后 级 和 路 径 ， 执 行 outputImage 方法 ， 输 出 图 像 
S$this->outputImage($img, $this->getExtendsName($imageUrl), $imageUID: 
imagedestroy($img]): /销毁 图 像 
imagedestroy($img): /销毁 图 像 
} 
技术 要 点 


使 用 图 片 来 作为 水 印 ， 前 提 是 这 个 图 片 的 背景 必须 是 透明 的 ， 否 则 输出 的 效果 很 不 理 
。263 。 四 
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想 。 图 片 水 印 添加 的 关键 是 getimagesize0 和 imagecopy0 函 数 。 应 用 getimagesizeO 函 数 获 
| 取 上 传 图 片 和 水 印 图 片 的 大 小 ， 通 过 imagecopy0 函 数 完成 图 片 水 印 的 添加 。 
| imagecopy0 函 数 ， 将 图 像 复 制 到 指定 的 另外 一 个 图 像 中 。 其 语法 如 下 : 
无 | bool imagecopy ( resource dst_im, resource SIc_im, int dst_x, int dst_y, int sre_x, int sre_y, int sre_w, 
-~ | 必 由 

将 src im 图 像 中 坐标 从 src_ x，src_y 开始 ， 宽 度 为 src_w， 高 度 为 src_h 的 一 部 分 复制 
| 到 dst_im 图 像 中 坐标 为 dst x 和 dst_y 的 位 置 上 。 
| 在 本 实例 中 ， 同 样 是 整合 图 像 的 创建 、 操 作 、 输 出 和 销毁 函数 ， 创 建 AddWaterPress 
| 类 ， 定 义 getExtendsName() 方 法 ， 获 取 上 传 图 片 的 文件 后 级 ; 定义 gettmageRes() 方 法 ， 根 
| 据 上 传 文件 的 后 级 创建 新 图 像 ， 定 义 outputImage0 方 法 ,输出 图 像 ， 定义 add0 方 法 ， 向 指 
| 定 的 图 片 中 添加 图 像 水 印 。 


实例 177 GD2 函数 生成 图 形 验证 码 


( 实例 位 置 : 配套 资源 \SL\10\177 视频 位 置 配套 资源 \SP\10\177 ) 


实例 说 明 
验证 码 技术 的 应 用 是 为 了 提高 站 点 的 安全 性 ， 避 兔 因 网 页 运行 速度 慢 而 造成 数据 的 
| 重复 提交 。 本 实例 将 通过 JavaScript 脚本 和 GD2 函数 开发 一 个 无 刷新 验证 码 ， 运 行 结 果 如 
| 图 10.5 所 示 。 


Email: ;mingrisof@mingrisoftcom } 


电话 : :0431-84978931 


| 图 10.5 GD2 函数 生成 图 形 验证 码 
| 实现 过 程 
具体 步骤 如 下 : 


(1) 创建 index.php 页 面 ， 定 义 form 表单 ， 设 计 用 户 注册 页 面 的 效果 。 
J 。264 。 
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(2) 创建 JavaSeript 脚本 ， 生 成 验证 码 :并 定义 reCode0 方 法 ， 用 于 验证 码 的 二 次 生 | 
成 。 其 关键 代码 如 下 : | 


<script language="javascript"> 

var numl=Math round(Math random()*10000000): // 生 成 随机 数 

var num=num!1 toString().substr(0.4): // 截 取 随 机 数 的 前 4 个 字符 
document write("<img name=codeimg src—"ValidatorCode.php?code="+num+">"); /将 值 传递 到 图 像 页 
forml.defvValidatorCode value=num: /将 截取 值 赋 给 表单 中 的 隐藏 域 
</script> 


(3) 创建 超 链 接 ， 调 用 JavaScript 脚本 中 的 reCode0 方 法 ， 实 现 验 证 码 的 二 次 生成 。 
其 代码 如 下 : 
<a href="javascript:reCode()" class="al"> 看 不 清 </a> | 
(4) 创建 ValidatorCode.php 页 面 ， 根 据 超 链接 中 传递 的 随机 数 ， 应 用 GD2 函数 生成 
验证 码 的 数字 图 像 。 其 关键 代码 如 下 : | 


<2php 

header('content-type:image/png); /定义 标题 png 格式 图 像 

S$im = imagecreate(65, 25); // 定 义 画 布 

imagefill($im, 0, 0, imagecolorallocate($im, 200, 200, 200)); // 区 域 填充 

$validatorCode = $_GET['code']:; // 获 取 提交 的 值 | 

imagestring(Sim, rand(3, 5) 10, 3, substtSvalidatorCode 0, 1), imagecolorallocate(Sim 0, rand(0, 255), | 
rand(0, 255))); | 

imagestring(Sim, rand(3, 5) 25, 6, substtSvalidatorCode 1, 1), imagecolorallocate(Sin, rand(0, 255), 0，| 
rand(0, 255))); | 

imagestring(Sin rand(3, 5), 36, 9, substr($validatorCode, 2, 1), imagecolorallocate($im, rand(0, 255), rand(0, | 
255), 0)); | 

imagestring(Sim, rand(3, 5), 48, 12, substr($validatorCode, 3, 1), imagecolorallocate(Sim, 0, rand(0, 255),| 
rand(0, 255))); | 

imagepng($im); // 生 成 png 图 像 

imagedestroy0O; 1/ 销毁 图 像 


(5) 在 js 文件 夹 下 ,创建 一 个 js 脚本 文件 ， 定 义 chkinput0 方 法 ， 对 表单 中 提交 的 注 | 
册 信 息 进行 验证 ， 包 括 验 证 码 是 否 正确 。 其 完整 代码 请 参考 本 书 配 套 资源 。 | 
技术 要 点 
应 用 JavaScript 脚本 和 GD2 函数 开发 一 个 无 刷新 验证 码 涉及 的 技术 包括 : 随机 数 的 生 | 
成 ， 随 机 数 如 何 传递 给 图 像 生成 页 ， 数 字 图 像 的 生成 ， 以 及 验证 码 的 二 次 生成 。 这 里 重点 | 
介绍 验证 码 图 像 的 生成 。 | 
(1) 创建 ValidatorCodephp， 应 用 GD2 函数 库 中 的 函数 ， 根 据 超 链接 传递 的 参数 值 | 
生成 验证 码 图 像 。 | 

加 ”imagecreate0 函 数 ， 创 建 验证 码 图 像 的 画布 。 

回 ”imagecolorallocate0 函 数 ， 定 义 画 布 的 填充 颜色 。 | 

回 imagefill0 函 数 ， 根 据 imagecolorallocateO 函 数 定 义 的 颜色 ， 完 成 图 像 颜色 的 填充 | 
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imagestring0) 函 数 ， 将 从 超 链 接 中 获取 的 验证 码 值 写 入 到 图 像 中 ， 并 且 应 用 
imagecolorallocate() 函 数 随 机 定义 值 输出 的 颜色 。 

imagepng() 函 数 ， 生 成 PNG 格式 的 图 像 。 

imagedestroy(0 函 数 ， 销 毁 图 像 ， 释 放 内 存 。 


(2) 验证 码 的 二 次 生成 。 其 实现 原理 类 似 于 do_while 循环 语句, 无论 条 件 是 否 满足 ， 


| 它 默认 都 会 执行 一 次 (打开 网 页 后 ， 直 接生 成 一 个 验证 码 )。 然 而 ， 要 想 其 继续 执行 ， 就 
| 必须 满足 指定 的 条 件 〈 重 新 生成 验证 码 ， 就 必须 调用 指定 的 方法 )。 依 据 这 个 原理 ， 在 
| JavaScript 脚本 中 定义 如 下 方法 : 


function reCodeO{ // 定 义 方法 ， 重 新 生成 验证 码 
var num1=Math.round(Math.random()*10000000): // 生 成 随机 数 
var num=numl.toString0.substr(0.4): /截取 随机 数 
documentcodeimg.src="ValidatorCode php?code="+num: /将 截取 值 传递 到 图 像 处 理 页 中 
forml.defValidatorCode.value=num: /将 截取 值 赋 给 表单 中 的 隐藏 域 
} 


在 上 述 的 方法 中 ， 重 复 执行 JavaScript 脚本 中 默认 的 操作 ， 即 重新 生成 一 个 验证 码 。 


| 多 学 两 招 ， 
| 在 本 实例 中 ， 应 用 GD2 函数 生成 的 是 清晰 的 数字 图 形 验 证 码 ， 还 可 以 在 此 基础 上 为 
| 验证 码 增加 干扰 背景 ， 使 其 看 上 去 模糊 一 些 ， 如 图 10.6 所 示 。 


图 10.6 增加 干扰 背景 后 的 验证 码 图 像 


| 其 具体 方法 如 下 : 在 ValidatorCode.php 文件 中 ,通过 for 循环 语句 ,应 用 imagesetpixel() 
| 函数 在 画布 的 背景 上 绘制 一 些 单一 元 素 。 代 码 如 下 : 


for ($i= 0; $i< 200; $i ++) { 1/ 填充 干扰 背景 
| imagesetpixel($im, rand() % 70, rand0 % 30, imagecolorallocate($im, rand(0, 255), rand(0, 255), 
| rand(0, 255))); 
| } 


实例 178 ”折线 图 分 析 2010 年 的 销售 额 


( 实例 位 置 配套 资源 \SL\10\178 视频 位 置 配套 资源 \SP\10\178) 


| 实例 说 明 
| 本 实例 运用 Jpgraph 生成 折线 图 ， 对 公司 2010 年 的 销售 额 进行 分 析 ， 运 行 结果 如 图 10.7 
所 示 。 
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.| 2010 年 销售 额 分 析 44 万 元 
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图 10.7 折线 图 分 析 2010 年 的 销售 额 
实现 过 程 
具体 步骤 如 下 : | 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导 入 所 需 的 存 | 

储 在 章 文 件 夹 10 下 的 Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 折线 图 ， 对 2010 年 公司 的 销售 额 进行 分 析 。 

其 代码 如 下 : 
$datayl = array(40,26,15,35,26,15,44,26,15,27,40,15); 


本 实例 通过 Jpgraph 类 库 创 建 折线 图 , 分析 2010 年 公司 的 销售 额 ， 旨 在 突出 如 何在 折 
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$graph = new Graph(650,375); /定义 图 像 大 小 
$graph->SetMarginColor(white)); /背景 颜色 
$egraph->SetScale("textlin"); // 定 义 刻 度 值 类 型 
$graph->SetFrame(false); 
$egraph->SetMargin(30,5,35,20); // 设 置 边 距 | 
$graph->tabtitle->Set(iconv("utf-8","gb2312""2010 年 销售 额 分 析 ) ); /输出 标题 | 
$eraph->tabtitle->SetFont(FF_SIMSUN, FS_BOLD.12); /设置 标题 字体 | 
$eraph->tabtitle->SetColor('darkred''#E1E1FF'); // 设 置 标题 颜色 | 
S$graph->xgrid->Show(): // 设 置 阴影 | 
Seraph->xaxis->SetTickLabels($gDateLocale->GetShortMonth0); /定义 和 轴 上 的 数据 | 
$pl = new LinePlot($datay]1): // 创 建 图 像 | 
$p1->SetColor("navy"): // 设 置 图 像 颜色 | 
$pl->mark->SetType(MARK _IMG'saab 95.jpg'.0.5): // 设 置 标签 的 样式 ， 使 用 图 片 | 
$p1->value->SetFormat('%d '.iconv("utf-8","gb2312", 万 元 "); /格式 化 数据 | 
$p1->value->Show0: // 输 出 阴影 | 
$p1->value->SetColorCdarkred)): /定义 颜色 | 
S$pl1->value->SetFont(FF_SIMSUN, FS_BOLD.,10): /设置 字体 | 
$p1->value->SetMargin(14): /设置 位 置 、 字 体 大 小 | 
$p1->SetCenter(): | 
$eraph->Add($p1): /添加 数据 | 
$graph->Stroke0: /生成 图 像 | 
技术 要 点 | 
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| 
| 线 图 中 通过 插入 的 图 像 设置 数据 点 标签 。 
| 应 用 图 像 中 mark 对 象 的 SetType0 方 法 ， 实 例 177 中 运行 本 方法 的 第 一 个 参数 ， 直 接 
”设置 标签 的 样式 ,在 本 实例 中 运用 SetType( 方 法 的 第 二 个 参数 ， 通 过 插入 的 图 像 设置 数据 
全 内。 ， 点 的 标 繁 ， 并 通过 第 三 个 参数 设置 插入 图 像 的 大 小 。 


实例 179 ” 柱 形 图 分 析 编程 词典 销售 比例 


( 实例 位 置 配套 资源 \SL\10\179 视频 位 置 : 配套 资源 \SP\10\179 ) 


| 实例 说 明 


| 木 实例 运用 Jpgraph 生成 柱 形 图 , 对 编程 词典 的 销售 比例 进行 分 析 , 运行 结果 如 图 10.8 
| 所 示 。 
| 编程 词典 销售 比例 分 析 
PR 
| 图 10.8 ” 柱 形 图 分 析 编 程 词典 销售 比例 
| 实现 过 程 
| 具体 步骤 如 下 : 


| (1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导 入 所 需 的 存 
| 储 在 章 文 件 夹 10 下 的 了 pgraph 文件 。 

| (2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 柱 形 图 ， 从 另外 一 个 角度 分 析 编程 词典 的 销 
| 售 比例 。 其 代码 如 下 : 


$datay=array(70.50,85.120,50): 
$datax=array("VB","VC","JAVA","C#","ASPNET"): 

S$width=500; // 定 义 图像 宽 
Sheight=600; // 定 义 图 像 高 
$graph = new Graph($width,$height,'auto"); /创建 图 像 
S$eraph->SetScale("textlin"); // 定 义 刻度 值 类 型 
S$top = 80; 
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$bottom = 30; 
Sleft = 80: 
Sright = 50; 
Sgraph->Set90AndMargin($left,$right,$top,$bottom); /设置 图 像 的 边 距 
$graph->title->Set(iconv("utf-8","gb2312"," 编 程 词典 销售 比例 分 析 ")); /定义 标题 
$egraph->title->SetFont(FF_SIMSUN, FS BOLD.,14): /设置 标题 字体 
$egraph->subtitle->Set("(2011-06)"); /设置 附 标题 
$eraph->xaxis->SetTickLabels($datax); /定义 和 轴 上 的 数据 
Seraph->xaxis->SetFont(FF VERDANAFS_ NORMAL.12): /设置 字体 
Seraph->xaxis->SetLabelAlign('right','center’); /设置 立轴 上 字体 右 侧 居中 
$graph->yaxis->scale->SetGrace(20): /设置 立轴 间距 
Seraph->yaxis->SetLabelAlign('center','bottom'); /设置 和 X 轴 字体 居中 ， 底 部 对 齐 
$graph->yaxis->SetLabelAngle(45); /设置 字体 的 倾斜 度 
$graph->yaxis->SetLabelFormat('%od):; // 输 出 数据 的 格式 
Segraph->yaxis->SetFont(FF VERDANA,FS NORMAL,12); // 设 置 字 体 
$bplot = new BarPlot($datay); // 创 建 图 像 
$bplot->SetFillColor("orange"): // 定 义 图 像 颜色 
S$bplot->SetShadowO:; /设置 图 像 阴影 
$bplot->value->Show(); /设置 数据 阴影 
$bplot->value->SetFont(FF_ARIAL.FS BOLD.,12): /设置 数据 字体 
$bplot->value->SetAlign('left','center’); // 设 置 数 据 位 置 
$bplot->value->SetColor("black","darkred"): // 设 置 数 据 颜色 
$bplot->value->SetFormat('%.1f):; /格式 化 数据 
Seraph->Add($bplot):; /添加 数据 
$graph->Stroke0; // 生 成 图 像 

技术 要 点 


本 实例 通过 Jpgraph 类 库 创建 柱 形 图 ， 分 析 编 程 词典 的 销售 比例 。 本 实例 中 创建 的 柱 
形 图 与 以 往 的 有 些 不 同 ， 这 里 将 柱 形 图 顺 时 针 旋 转 了 90”。 

其 主要 应 用 图 像 对 象 中 的 Set90AndMargin0 方 法 ， 完 成 柱 形 图 的 顺 时 针 90” 旋 转 。 其 
语法 如 下 : 

Set90AndMargin($lm, $rm, $tm, $bm) 

参数 说 明 : 
$lm: 左边 框 旋转 角度 。 
$rm: 右边 框 旋转 角度 。 
$tm: 上 边框 旋转 角度 。 
$bm: 下 边框 旋转 角度 。 


实例 180 人 饼 形 图 分 析 2010 年 图 书 销量 


( 实例 位 置 : 配套 资源 \SL\10\180 视频 位 置 : 配套 资源 \SP\10\180 ) 


| 


实例 说 明 
本 实例 运用 Jpgraph 生成 饼 形 图 ， 对 公司 年 度 总 的 收 支 情况 进行 分 析 ， 运 行 结果 如 
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图 10.9 所 示 。 


图 10.9 饼 形 图 分 析 2010 年 图 书 销量 


实现 过 程 

| 具体 步骤 如 下 

| (1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导入 所 需 的 存 
| 储 在 章 文件 来 10 下 的 Jpgraph 文件 。 

| (2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2010 图 书 销量 进行 分 析 。 其 代 
| 人 码 如 下 : 


| <?php 
| header ( "Content-type: text/html:; charset=UTF-8" ); /设置 文件 编码 格式 
| include ("../src/ipgraph.php"); 
| include ("../src/jpgraph_pie.php"); 
| include ("../src/jpgraph_pie3d.php"); 
| $data = array(20,27,45,75,90,30): 
| $graph = new PieGraph(500,275,"auto"); 1/ 创建 图 像 
| $graph->SetShadow(): // 输 出 阴影 
| $egraph->tabtitle->Set(iconv("utf-8","gb2312",'2010 年 图 书 销售 分 析 ) ); /输出 标题 
| $graph->tabtitle->SetFont(FF_SIMSUN, FS_BOLD.18): /设置 标题 字体 
| $eraph->title->SetColor("darkblue"): /定义 标题 颜色 
| $graph->legend->Pos(0.1.0.2); // 控 制 注释 文字 的 位 置 
| $pl = new PiePlot3d($data): /创建 3D 饼 形 图 图 像 
| $pl->SetTheme("water"): // 控 制图 像 颜色 的 主题 
| $p1->SetCenter(0.35): // 控 制图 像 的 大 小 比例 
| $pl->SetAngleG30): // 控 制图 像 的 倾斜 角度 
| $p1->value->SetFont(FF_ARIAL,FS NORMAL.12): // 设 置 字体 
| $p1->SetLegends(array("ASPNET","C#","JAVA","PHP"."VB","VC")): 
| $graph->Add($p1): /添加 数据 
| $eraph->StrokeO: // 生 成 图 像 
| ?> 
贞 


Ea 


本 实例 通过 Jpgraph 类 库 创 建 饼 形 图 , 分 析 2010 年 图 书 销量 ， 旨 在 突出 饼 形 图 的 创建 


(1) 创建 饼 形 图 图 像 应 用 PieGraph 类 ， 它 继承 Graph 类 ， 创 建 3D 饼 形 图 的 图 像 。 
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(2) 创建 3D 饼 形 图 应 用 PiePlot3D 类 ， 继 承 PiePlot 类 。 | 
(3) 通过 图 像 中 的 legend 对 象 调用 Pos0 方 法 定位 饼 形 图 在 图 像 中 的 存储 位 置 。 Pos0 | 
方法 的 语法 如 下 : | 
Pos($aX, $aY, SaHAlign, $aVAlien) 
参数 说 明 : 
$aX: 设置 距离 X 轴 的 位 置 。 
回 $aY: 设置 距离 Y 轴 的 位 置 。 
回 $aHAlign: 设置 右 侧 (居中 、 居 左 或 者 居 右 〉。 
加 ”$aVAlign: 设置 顶部 〈 居 下 、 居 上 或 者 居中 ) 。 | 
(4) 通过 饼 形 图 对 象 调用 SetTheme() 方 法 设置 饼 形 图 的 颜色 。 SetTheme0 方 法 的 语法 | 


如 下 : 


PiePlot :: 
SetTheme($aTheme) 


参数 $aTheme 指定 主题 的 名 称 , 其 支持 的 主题 包括 “earth”、“pastel”、“sand”、“water”。 | 
多 学 两 招 : 


在 Jpgraph 类 库 中 ， 通 过 饼 形 图 对 象 中 SetCenter( 方 法 控制 饼 形 图 的 大 小 比例 ， 默 认 | 
值 是 0.5; 通过 SetAngle() 方 法 控制 图 像 的 倾斜 角度 ， 倾 斜 角度 必须 在 10。 ~80* 之 间 。 | 


实例 181 GD2 函数 折线 图 分 析 网 站 月 访问 量 走 分 


( 实例 位 置 : 配套 资源 \SL\10\181 ) 


实例 说 明 | 
本 实例 运用 GD2 函数 自行 编写 一 个 绘制 折线 图 的 方法 ， 对 2010 年 公司 网 站 的 月 访问 | | 


量 进行 分 析 。 其 中 的 方法 完全 由 笔者 自行 编写 ,不 借助 于 任何 图 像 的 操作 类 库 ， 运 行 结 厅 | 
如 图 10.10 所 示 。 | 


Apri June July pug Sep 0ct Nov Dec 
Fry 59X 0.78X 6.58X 1.17% 3.94X 2.27X 4.82X 9.5X% 0.59X% 4.91X 43.39X 2.47X 


图 10.10 GD2 函数 折线 图 分 析 网 站 月 访问 量 走势 
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具体 步骤 如 下 : 

(1) 创建 mdexphp 文件 ， 定 义 表单 ， 添 加 12 个 表单 元 素 ， 提 交 网 站 的 月 访问 量 数据 。 

(2) 创建 img.php 文件 ， 获 取 表 单 中 提交 的 网 站 月 访问 量 数据 ， 并 对 数据 统计 分 析 。 
通过 GD2 函数 创建 一 个 折线 图 输出 统计 分 析 的 结果 。 其 关键 代码 如 下 : 


<7php 
$data = array ($_ POST ["T1"], $ POST ["T2"], $_ POST ["T3"], $_ POST ["T4"], $ POST ["T5"], 


$ POST ["T6"],$_ POST ["T7"],$_ POST ["T8"],$_ POST ["T9"],$_ POST ["T10"],$ POST ["T11"],.$_ POST 


["T12"]); 


"Dee"); 


$month = array ("Jan", "Feb", "March" "April" "May", "June", "July" "Aug", "Sep", "Oct", "Nov", 
$max = 0; 
for($i= 0; $i< 12; $i1++) { 
Smax = $max + $data [$1]; // 所 有 网 站 访问 量 的 累加 和 
$im = imagecreate ( 550, 300 ); // 创 建 画 布 
$green = imagecolorallocate ( $im, 214, 235, 214 ):; // 设 置 颜色 值 


Sblack = imagecolorallocate ( $im, 0, 0, 0 ); 
S$red = imagecolorallocate ( $im, 255, 0, 0 ); 
S$blue = imagecolorallocate ( $im, 0, 0, 255 ): 
imageline ( $im, 30, 230, 520, 230, $blue ); // 设 置 X 轴 横 坐标 
imageline ( $im, 30, 5, 30, 230, $blue ); // 设 置 Y 轴 纵 坐 标 
imagestring ( $im, 3, 520, 222, "X", $black ); // 输 出 字符 义 
imagestring ( $im, 3, 16, 1, "Y", $black ); /输出 字符 并 
$1= 190; 
$kl = 30; 
$k2 = 510; 
for($j =0;$j <12; $j ++) { 
imageline ( $im, $k1, $1, $k2, $1, $black ): /设置 科 轴 网 格 线 横 坐 标 
$1= $1- 40; 
} 
$f = 70; 
$zl = 20; 
$72 = 228; 
for($j =0; $j <12: 8 + { 
imageline ( $im, Sf $z1, $f, $72, $black ): /设置 立轴 网 格 线 纵 坐 标 
$f= $f + 40; 
} 
$1 = 185; 
for($j =1: $j <6: 9 +H) { 
imagestring ( $im, 2, 2, $1 20 * $j . "%", $red ); 
$1= $1- 40; 
上 
$x = 20; 
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$y = 230; 

for($i= 1; $i< 12; $1++) { 
$y lt= $y - (($data [$i- 1]/ $max) * 200): // 设 置 网 站 访问 量 的 纵 坐 标 值 
$y_ht= $y - (($data [$i] / $max) * 200); // 获 取 每 月 网 站 访问 量 数 的 纵 坐 标 值 


imageline ( $im, $x * ($i* 2 - 1)+30, $y lt, $x * ($i+ 1)*2-1)+30, $y_ht, $red ); // 绘 制 网 站 访 | 
问 量 折 线 图 | VY 


) 


for($i= 1; $i1<13; $i++) { 
$rl = round ( (($data [$i- 1]) / $max) * 100, 2 ); 
imagestring ( $im, 2, $x * ($i- 1) * 2+ 40, $y + 11, $month [$i - 1], $black ); // 输 出 月 份 的 值 
imagestring ( $im, 2, $x * ($i- 1) * 2+ 36, $y + 25, Srl . "%", $red ); // 输 出 网 站 访问 量 的 百分比 
} 
imagepng ( $im ); 
imagedestroy ( $im ); // 释 放 图 像 资源 
本 实例 通过 GD2 函数 绘制 网 站 访问 量 走势 分 析 图 ， 其 中 所 涉及 的 关键 技术 如 下 : 
(1) 应 用 imageline0 函 数 绘制 线条 。 
imageline() 函 数 用 指定 颜色 在 图 像 中 两 点 之 间 绘 制 一 条 线段 ， 语 法 如 下 : 


bool imageline ( resource image, int x1, int yl, int x2, int y2, int color ) 


参数 说 明 : 

image: 图 像 标 识 。 

x1: 起 始点 的 横 坐 标 。 

yl1: 起 始点 的 纵 坐 标 。 

x2: 结束 点 的 横 坐 标 。 

y2: 结束 点 的 纵 坐 标 。 

color: 颜色 标识 。 | 

(2) 应 用 百分比 来 显示 数据 信息 ， 并 通过 round0 函 数 将 数字 小 数位 进行 四 舍 五 入 操 | 

round0) 函 数 语 法 如 下 : | 
double round(double val) 


参数 var 为 进行 四 舍 五 入 操作 的 小 数 。 


| 


作 


实例 182 GD2 函数 柱状 图 分 析 编 程 词典 满意 度 调 查 


( 实例 位 置 : 配套 资源 \SL\10\182 ) 


实例 说 明 

在 网 站 中 ， 经 常 需要 对 相关 的 信息 进行 调查 统计 ， 然 后 根据 访问 者 的 投票 结果 制定 相 
关 计 划 。 为 了 能 够 更 直观 地 查看 访问 者 的 投票 结果 ， 本 实例 采用 柱 形 图 显示 编程 词典 满意 | 
度 的 投票 结果 ， 运 行 结果 如 图 10.11 所 示 。 | 


7 L_ 


nr 
100X | 
80X Ex | 
ox | 
40% 
Foy 8.07 刘 | 

| x 
好 良好 一 般 是 


『 声 程 词 忠 滋 素 度 调查 」 栏 下 续 失 


图 10.11 GD2 函数 柱状 图 分 析 编程 词典 满意 度 调查 


具体 步骤 如 下 : 


(1) 创建 index.php 页 面 ， 编 写 img 标签 输出 img.png 图 像 ， 即 输出 柱 形 图 统计 结果 。 
(2) 创建 img.php 文件 ， 从 数据 库 中 读 取 数据 ,将 从 数据 库 中 读 取 的 数据 以 柱 形 图 形 


式 进行 输出 。 其 关键 代码 如 下 : 


<?php 


header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 


include ("conn/conn.php"); 


$query = mysql_ query ( "select sum(ticket) as total from tb_comment" ); 


S$info = mysql fetch array ( $query ): 
$max = $info [total]; 


// 所 有 投票 的 累加 和 


$sql = mysql_query ( "select * from tb_comment" ); 


Sresult = mysql_fetch array ( $sql ); 
$im = imagecreate ( 350, 300 ); 


$green = imagecolorallocate ( $im, 233, 240, 151 ); 


S$black = imagecolorallocate ( $im, 0, 0, 0 ); 
Sred = imagecolorallocate ( $im, 255, 0, 0 ); 
S$blue = imagecolorallocate ( $im, 0, 0, 255 ): 
imageline ( $im, 30, 230, 290, 230, $blue ): 
imageline ( $im, 30, 5, 30, 230, $blue ); 
imagestring ( $im, 3, 295, 222, "X", $black ); 
imagestring ( $im, 3, 16, 1, "Y", $black ); 
$1= 190; 
$kl = 30; 
$k2 = 280; 
for($j = 0; $j <5; $j ++) { 
imageline ( $im, $k1, $1, $k2, $1, $black ): 
$1= $1- 40; 
1 
$f = 80; 
$zl = 20; 
$z2 = 228: 
for($j =0: $j <4. 8+ { 
imageline ( $im, $f, $z1, $f, $72, $black ): 
$f= $f+ 50; 
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/检索 数据 信息 
/创建 画布 
/设置 颜色 值 


/设置 X 轴 横 坐 标 
/设置 了 轴 纵 坐标 
// 输 出 字符 了 
// 输 出 字符 YY 


/设置 和 轴 网 格 线 横 坐 标 


/设置 了 轴 网 格 线 纵 坐 标 
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} 

$1 = 185; 

for($j =1; $j <6; $++) { 
imagestring ( $im, 2, 2, $1, 20 * 3j . "%", Sred ): 
Y= =A0: 


让 ($result [comment] 一 "好 ") { 
$comment = "好 "; // 定 义 输出 字体 串 


} 
站 ($result [comment] 一 "良好") { 
Scomment = "良好 "; 


} 
让 ($result [comment] 一 "一般") { 
$comment = "一 般 "; 


} 
过 ($result [comment] 一 " 差 ") { 


$comment = " 差 "; // 定 义 输出 字体 串 
} 
$fnt = "Font/FZHCJW.TTF"; // 定 义 字体 
$y_ht = round ( ($result [ticket] / $max) * 200, 2 ); 1/ 设 置 投票 结果 所 占 百分比 
$y_ht] =round ( ($result [ticket] / $max) * 100, 2 ); /设置 投票 结果 所 占 百分比 


imagefilledrectangle ( $im, $x, $y, $x + $x_width, $y - $y_ht, $red ); /绘制 并 填充 柱 形 图 


imagestring ( $im, 2, $x + $x_width - 20, $y - $y_ht - 20, $y_htl . "%", $black ); /设置 投票 结果 所 


占 百分比 


imageTTFText ( $im, 15, 0, 10, $y + 50, $black, $fnt, $text ); // 号 TIF 文字 到 图 中 
imagedestroy ( $im ):; /释放 图 像 资源 
> 

指点 迷津 : 


本 实例 运用 的 是 UTF-8 编码 格式 ， 所 以 在 图 像 中 输出 中 文字 符 串 时 可 以 直接 应 用 
imageTTFTextO 函 数 ; 但 是 ， 如 果 页 面 使 用 的 是 GB2312 编码 格式 ， 那 么 要 输出 中 文字 符 


imageTTFText ( $im, 15, 0, $x + 2, $y + 20, $black, $fnt, $comment ); // 写 TTF 文字 到 图 中 
$x += ($x_width + 30): /设置 两 柱 形 图 之 间 的 宽度 为 30 像素 


} while ( $result = mysql_fetch_array ( $sql ) ); 
$text ="『 编程 词典 满意 度 调查 」 投票 结果 "; 


串 时 ， 就 必须 将 中 文字 符 串 转换 成 UTF-8 编码 格式 ， 否 则 将 输出 乱码 。 


技术 


通过 GD2 函数 创建 柱 形 图 ， 关 键 是 imagefilledrectangleO 函 数 ， 通 过 它 完 成 柱 形 图 的 


Pa 


绘制 及 填充 。 


imagefilledrectangle0) 函 数 ， 在 图 像 中 绘制 一 个 用 指定 颜色 填充 的 矩形 ， 其 语法 如 下 : 


bool imagefilledrectangle ( resource image, int x1, intyl, int x2, int y2, int color ) 
275% 
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参数 说 明 : 

image: 图 像 资源 。 

x1: 柱状 图 左上 角 横 坐标 。 

yl: 柱状 图 左上 角 纵 坐标 。 

x2: 柱状 图 右 下 角 横 坐标 。 

y2: 柱状 图 右 下 角 纵 坐标 。 

color: 填充 颜色 。 

在 本 实例 中 ， 将 从 数据 库 中 读 取 的 数据 以 柱 形 图 的 形式 进行 展示 ， 实 现 柱 形 图 与 数据 


回回 网罗 网 网 


| 库 中 数据 的 完美 结合 。 


| 实例 说 明 


实例 183 GD2 欧 数 饼 形 图 分 析 图 书市 场 的 份额 


( 实例 位 置 : 配套 资源 \SL\10\183 ) 


在 调查 某 类 商品 的 市 场 占有 率 的 时 候 ， 最 好 的 显示 方式 就 是 使 用 饼 形 图 。 通 过 饼 形 图 


可 以 直观 地 看 到 某 类 产品 的 不 同 品 牌 在 市 场 中 的 占有 比例 。 运 行 本 实例 ， 通 过 饼 形 图 将 不 
| 同 语言 的 软件 图 书 在 市 场 中 的 占有 率 显示 出 来 ， 运 行 结果 如 图 10.12 所 示 。 


总 的 图 书 销量 :16300 

ED 

me HD |?) 必 ，3|% 
mw J CD) 4 . ZR% 
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图 10.12 GD2 函数 饼 形 图 分 析 图 书市 场 的 份额 
现 过 程 
具体 步 又 如 下 
(1) 创建 index.php 文件 ， 连 接 数据 库 ， 执 行 查询 语句 ， 获 取 数 据 库 中 总 的 图 书 销量 


| 值 ， 并 通过 img 标签 调用 图 像 处 理 文件 caky img php。 


(2) 创建 caky_img.php 文件 ,通过 饼 形 图 和 柱 形 图 联合 分 析 各 语言 图 书市 场 的 份额 。 


首先 , 获取 表单 中 传递 的 总 的 图 书 销量 值 , 并 计算 各 部 门 图 书 销量 值 占 总 图 书 销量 的 比例 。 
| 然后， 根据 比例 值 创建 饼 形 图 。 最 后 ， 通 过 柱 形 图 输出 不 同 的 颜色 区 块 代表 相应 语言 的 图 


书 。 其 关键 代码 如 下 : 


<?php 
include ("conn/conn.php"); /连接 数据 库 
$query = mysql query ( "select product count from tb _data " ): // 执 行 查询 语句 
$data = array 0: /定义 空 数组 
while ( $myrow = mysql fetch array ( $query ) ) { 
$data [] = $myrow [product_count]; // 将 查询 结果 写 入 到 数组 中 
} 
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$widths = 580: /定义 图 像 宽度 | 
Sheights = 150; /定义 图 像 高 度 | 
$width = 280: // 定 义 饼 形 图 宽度 | 
Sheight = 130: // 定 义 饼 形 图 高 度 | 
$angle = array (); /角度 | 
S$total = 0; | vy 
for($i= 0; $i < count ( $data ): $i ++) { | 
if(!is numeric ( $data [$i] )) // 判 断 数 组 中 的 值 是 否 为 空 
die ("1"); | 


Stotal += $data [$i]; 
} | 
for($i= 0; $i < count ( $data ); $i ++) { | 
array_push ( $angle, round ( 360 * $data [$i] / $total ) ); // 定 义 饼 形 图 的 角度 值 | 
} | 
Simage = imagecreate ( $widths, $heights ); // 创 建 饼 形 图 的 画布 
$white = imagecolorallocate ( $image, OxEE, OxEE, OxEE ); /定义 背景 颜色 
$color= array (array (imagecolorallocate ( $image, 0x97, 0xbd, 0x00) ); /定义 图 像 的 颜色 值 


Srounds x = $width /2; // 原 线 
for($h = Sheight /2+ 5: $h > Sheight /2- 5: Sh -) { 

$start = 0: 

$stop = 0; 


for($i= 0; $i< count ( $data ); $i1++) { 
$start = $start + 0; 
$stop = $start + $angle [$1]; 
S$color i= fmod ( $i, 10 ):; | 
imagefilledarc ( $image, $rounds x, $h, $width, $height - 20, $start, $stop, $color 口 | 


[$color i], IMG ARC PIE ); // 创 建 饼 形 图 
S$start += $angle [$1]; 
$stop += $angle [$1]; 
} 


} 

39 for($i= 0; $i< count ( $data ); $i++) { 
$start = $start + 0; 
$stop = $start + $angle [$i]; 
$color i= fmod ( $i, 10); | 
imagefilledarc ( $image, S$rounds x, $h, $width, $height - 20, $start, $stop, $color 四 

[$color i], IMG _ ARC PIE ); 

S$start += $angle [$i]: 


$stop += $angle [$i]; | 

) 

$fnt = "FontFZHCJWTTF": /定义 字体 | 

Sm=- 1; | 

$result = mysql query ( "select * from tb data " ): // 读 取 数 据 库 中 存储 的 数据 | 

while ( $myrow = mysql fetch array ( $result )) { //while 循环 输出 数据 库 中 数据 | 

Sm tt; | 
imagefilledrectangle ( $image, 295, 15 + 20 * $m, 380.5+ 20 * $m, $color [0] [$m] ): /绘制 并 填充 ， 

柱 形 图 | 
Scomment = $myrow [product name] . ": " . number format ( $myrow [product countl / | 

$_GET [counts], 2 ) * 100 . "%"; // 输 出 柱 形 图 | 
imageTTFText ( $image, 15, 0, 390, 18 + 20 * $m, $color [0] [$m], $fnt, Scomment ); // 写 TIF 文字 | 

到 图 中 | 
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} 
imagepng ( $image ); 
imagedestroy ( $image ); 
| ?> 
人 色 | | (3) 创建 conn 文件 夹 ， 定 义 conn.php 文件 ， 连 接 MySQL 数据 库 服务 器 ， 连 接 db_ 
database10 数据 库 ， 并 设置 数据 库 编码 格式 为 UTF-8。 
| 技术 要 点 
(1) 绘制 椭圆 使 用 GD2 函数 库 中 的 imagefilledarc0 函 数 ， 该 函数 在 指定 图 像 标识 所 
| 代表 的 图 像 中 以 图 像 左上 角 为 坐标 点 绘制 一 顶 圆 弧 。 如 果 成 功 ， 则 返回 re， 否则， 返回 


| false。 该 函数 的 语法 如 下 : 


加 网 网 加 网 网 回 网 网 站 


bool imagefilledarc ( resource image, int cx, int cy, int w, int h, int s, int e, int color int style ) 


参数 说 明 : 


image: 图 像 标 识 。 

cx: 图 像 左 上 角 横 坐标 。 

cy: 图 像 左上 角 纵 坐标 。 

w: 椭圆 的 宽度 。 

h: 椭圆 的 高 度 。 

s: 以 角度 指定 椭圆 的 起 始点 。 

e: 以 角度 指定 椭圆 的 结束 点 。 

color: 颜色 标识 。 

style: 可 以 是 IMG _ARC PIE、 IMG _ARC_CHORD、IMG ARC NOFILL、IMG _ 
ARC_EDGED 按 位 或 (OR) 后 的 值 , IMG_ARC PIE 和 IMG _ARC _CHORD 是 互 
斥 的 。IMG_ARC _CHORD 只 是 用 直线 连接 了 起 始 和 结束 点 ，IMG_ARC _PIE 则 
产生 圆 形 边界 (如 果 两 个 都 用 ,IMG_ARC_CHORD 生效 ) 。IMG_ARC _NOFILL 
指明 弧 或 弦 只 有 轮廓 ， 不 填充 。IMG_ARC_EDGED 指明 用 直线 将 起 始 和 结束 点 
与 中 心 点 相连 ， 和 IMG _ARC _NOFILL 一 起 使 用 是 绘制 饼 状 图 轮廓 的 好 方法 〈 而 
不 用 填充 ) 。 


| (2) 同时 应 用 绘制 柱 形 图 的 方法 ， 通 过 柱 形 图 展示 不 同 颜色 代表 的 数据 。 有 关 柱 形 
| 图 的 应 用 请 参考 实例 182。 

| (3) 充分 展示 数据 库 中 数据 与 图 形 结合 的 方法 。 分 别 运 用 for 语句 和 while 语句 对 数 
| 据 库 中 的 数据 进行 循环 输出 。 


实例 184 柱状 图 展示 编程 词典 6、7 月 份 销售 量 


( 实例 位 置 : 配套 资源 \SL\10\184 ) 


| 实例 说 明 


本 实例 运用 Jpgraph 生成 对 比 柱状 图 ， 对 编程 词典 6、7 月 份 的 销售 量 进行 比较 ， 运 行 
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结果 如 图 10.13 所 示 。 | 


性 词典 2011 年 6、7 
编程 词 年 6、7 月 份 销售 对 比 A | 
! 
120 202.0 ! 
189.0 ! 
9.0 本 105.0 200 ! 
RR” 90.0| a 92: | 
|. 45.0 | 
Eeo es 1 
里 63.9| - 
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! 
50 
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| 
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图 10.13 柱状 图 展示 编程 词典 6、7 月 份 销量 
实现 过 程 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导入 所 需 的 存 
储 在 章 文 件 夹 10 下 的 Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 完成 对 比 柱 形 图 的 创建 ， 其 关键 代码 如 下 : 


<2php 

header ( "Content-type: text/html:; charset=UTF-8" ): /设置 文件 编码 格式 
include ("../src/jpgraph.php"): // 导 入 文件 

include ("../src/ipgraph_bar.php"); // 导 入 文件 
$data_july = array(90, 63, 69, 105, 92); /设置 统计 数据 
$data june = array(180, 173, 189, 145, 202); /设置 统计 数据 
$datazero=array(0,0,0,0,0); 

$datas = array("C#", "VB", "VC", "JAVA", "ASPNET"); // 设 置 统计 数据 
$graph = new Graph(600,270); // 创 建 图 像 
$egraph->SetScale("textlin"):; // 设 置 坐 标 刻度 类 型 
Seraph->SetY2Scale("lin"); 

$egraph->img->SetMargin(50, 40, 20, 40); /设置 统计 图 边 距 


S$eraph->yaxis->scale->SetGrace(20); 
$eraph->y2axis->scale->SetGrace(20); 


$egraph->SetMarginColor('white'): // 创 建 背景 颜色 
$eraph->y2axis->SetColor('darkred"); 

$bplotzero = new BarPlot($datazero): /设置 图 像 的 填充 值 
$ybplotl = new BarPlot($data july): /创建 6 月 份 数据 


$ybplotl->value->Show0:; 

$ybplot = new GroupBarPlot(array($ybplot1,$bplotzero)): 

$ybplot2 = new BarPlot($data june): /创建 7 月 份 数据 
$ybplot2->value->Show0: // 输 出 数据 
$ybplot2->value->SetColorCdarkred); | 
$ybplot2->SetFillColor('darkred"); | 
$y2bplot = new GroupBarPlot(array($bplotzero.$ybplot2)): 
/将 数据 添加 到 图 像 中 | 
$graph->Add($ybplob: | 
$eraph->AddY2($y2bplot); 
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$egraph->title->Set(iconv("utf-8","gb2312", 编 程 词典 2011 年 6、7 月 份 销售 对 比 ")); /设置 统计 图 标题 


$egraph->xaxis->title->Set(iconv("utf-8","gb2312",6、7 月 份 ); // 设 置 义 轴 名 称 
Sgraph->xaxis->SetTickLabels($datas); 
| $graph->yaxis->title->Set(iconv("utf8","gb2312".' 总 金额 (万 元 )7): /设置 立轴 名 称 
全 | Seraph->title->SetFont(FF_SIMSUN, FS _ BOLD): // 设 置 标题 字体 
| $eraph->xaxis->title->SetFont(FF_SIMSUN.,FS_ BOLD): // 设 置 义 轴 字体 
| Seraph->yaxis->title->SetFont(FF_SIMSUN,FS_BOLD); 1/ 设置 了 轴 字体 
S$egraph->Stroke(); // 生 成 图 像 
| > 
”技术 要 点 


| 本 实例 通过 柱状 图 完成 对 编程 词典 6、7 月 份 销量 的 对 比 。 它 在 单一 柱状 图 的 基础 上 
| 增加 一 组 柱状 图 ， 形 成 两 组 数据 的 对 比 效 果 ， 其 实现 方法 与 单一 柱状 图 是 相同 的 ， 可 以 说 
| 是 创建 两 个 单一 的 柱状 图 ， 然 后 将 其 在 同一 图 像 中 输出 。 
| (1) 通过 BarPlot 类 创建 柱状 图 ， 运用 其 返回 对 象 调用 value0 方 法 ， 调 用 value0 方 法 
| 中 的 Show0 方 法 输出 数据 ， 通 过 SetColor( 方 法 设置 输出 数据 颜色 。 
| SetColor() 方 法 的 语法 如 下 : 
SetColor($aColor, $aLabelColor) 
加 ”$aColor: 设置 坐标 轴 的 颜色 。 
加 ”$aLabelColor: 默认 值 为 false， 设 置 坐标 轴 上 标签 的 颜色 。 
| (2) 通过 Add0 方 法 将 柱状 图 数据 添加 到 图 像 中 ， 其 参数 是 柱状 图 创建 返回 的 对 象 。 
| 语法 如 下 : 
| Graph :: 
Add($aPlot) 
参数 $aPlot 指定 图 像 创建 时 返回 的 对 象 。 
| (3) 在 本 实例 中 ， 还 应 用 到 了 GroupBarPlot 类 创建 柱状 图 数组 ， 通 过 该 类 可 以 实现 
| 对 柱状 图 的 分 段 处 理 ， 如 果 重 新 设置 数组 $datazero 的 值 ， 就 会 发 现 柱状 图 有 一 些 变化 。 
| Class GroupBarPlot Extends BarPlot 


GroupBarPlot :: 
GroupBarPlot($plots) 


GroupBarPlot 创建 一 个 新 的 图 像 对 象 ，$plots 是 一 个 数组 。 


实例 185 ”柱状 图 展示 编程 词典 上 半年 销量 


( 实例 位 置 : 配套 资源 \SL\10\185 ) 


| 实例 说 明 
本 实例 运用 Jpgraph 生成 柱状 图 ， 对 公司 编程 词典 上 半年 的 销量 进行 统计 ， 运 行 结果 
| 如 图 10.14 所 示 。 
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图 10.14 柱状 图 展示 编程 词典 上 半年 销量 | 
实现 过 程 
具体 步 又 如 下 : 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导 入 所 需 的 存 
储 在 章 文 件 夹 10 下 的 Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 完成 特殊 柱状 图 的 创建 ， 其 关键 代码 如 下 : | 
<?php 
header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 
include ("../sre/ipgraph.php"): | 
include ("../src/jpgraph_ bar. php"): | 


$datay=array(150,201,145,340.265.365): | 
S$datax=array("Jan","Feb","Mar","Apr","May","June"): | 


$graph = new Graph(400,200,"auto"): /创建 图 像 
$graph->img->SetMarein(60.20.30.50): /设置 图 像 边 框 间距 
$egraph->SetScale("textlin"): /定义 坐标 刻度 类 型 
$egraph->SetMarginColor("lightblue"); // 定 义 图 像 颜 色 
$graph->title->Set(iconv("utf-8","gb2312", 编 程 词典 上 半年 总 的 销售 量 分 析 ')); /定义 标题 
Seraph->title->SetFont(FF_SIMSUN, FS_BOLD): // 设 置 标题 字体 | 
Seraph->xaxis->SetFont(FF VERDANA,FS NORMAL,10); // 设 置 义 轴 的 字体 | 
Seraph->yaxis->SetFont(FF VERDANA.FS NORMAL,10); /设置 立轴 的 字体 | 
$graph->xaxis->SetTickLabels($datax): /设置 和 X 轴 输出 的 数据 | 
$graph->xaxis->SetLabelAngle(50): /设置 输出 文字 大 小 | 
$bplot = new BarPlot($datay): /实例 化 图 像 创建 类 | 
$bplot->SetWidth(0.6): // 设 置 柱 形 图 的 输出 大 小 | 
$bplot->SetFillGradient("navy","#FFFF00",GRAD_LEFT_REFLECTION);// 设 置 图 像 的 类 型 和 填充 | 
颜色 ! 
$bplot->SetColor("white"): // 设 置 图 像 边 框 颜色 | 
$eraph->Add($bplot): /添加 数据 | 
$graph->Stroke0: /生成 图 像 | 
?> | 
技术 要 点 | 


本 实例 对 编程 词典 上 半年 的 销量 进行 分 析 ， 这 里 创建 的 柱状 图 与 上 面 创建 的 柱状 图 唯 | 
一 的 区 别 是 形状 和 颜色 不 同 。 | 
在 本 实例 中 ， 设 置 柱状 图 形状 是 通过 BarPlot 类 中 的 SetFillGradient0 方 法 完成 颜色 、 | 
形状 的 设置 ， 其 语法 如 下 : | 
SetFillGradient($aFromColor, $aToColor, $aStyle) 
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参数 说 明 : 
$aFromColor: 默认 颜色 。 
| 加 ”$aToColor: 转换 的 颜色 。 
| 加 ”S$aStyle: 设置 的 样式 。 
| 本 实例 中 的 具体 应 用 如 下 : 
SetFillGradient ("navy","#FFFF00",GRAD LEFT_REFLECTION);”// 设 置 图 像 的 类 型 和 填充 颜色 


| 实例 186 ”折线 图 分 析 2010 年 牛肉 市 场 价 格 走势 


( 实例 位 置 : 配套 资源 \SL\10\186 ) 


实例 说 明 
| 本 实例 运用 Jpgraph 生成 折线 图 ,对 2010 年 牛肉 市 场 价格 走势 进行 分 析 ， 运行 结果 如 
| 图 10.15 所 示 。 


2010 年 牛肉 市 场 的 价格 分 析 
$20.0 


(" 
单位 : 元 /月 份 


图 10.15 ”折线 图 分 析 2010 年 牛肉 市 场 价格 走势 

| 实现 过 程 

| 具体 步骤 如 下 : 

| (1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导 入 所 需 的 存 
| 储 在 章 文件 夹 10 下 的 Jpgraph 文件 。 

| (2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 折线 图 ， 对 2010 年 牛肉 市 场 价格 走势 进行 
分 析 。 其 代码 如 下 : 


$ydata = array(12,18,15,17,16,20,17,13,15,17,15,16): // 定 义 数 据 
$graph = new Graph(450,300,"auto"); /创建 图 像 
S$graph->SetScale("textlin"): // 定 义 刻 度 值 类 型 
Seraph->img->SetMargin(50,40,40,55): /设置 边框 的 间距 
| S$lineplot=new LinePlot($ydata): // 创 建 折线 图 
| Slineplot->mark->SetType(MARK UTRIANGLE): // 定 义 折线 图 的 标记 点 
| $lineplot->value->show0: // 输 出 折线 图 对 应 的 值 
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S$lineplot->value->SetColor('darkred"); // 设 置 值 的 颜色 
S$lineplot->value->SetFont(FF_FONT1,FS BOLD): // 设 置 值 的 字体 
Slineplot->value->SetFormat('$%0.1f): // 对 值 进行 格式 化 
$eraph->Add($lineplot); // 添 加 数据 


$graph->title->Set(iconv("utf-8","gb2312","2010 年 牛肉 市 场 的 价格 分 析 "));// 定 义 标题 
$egraph->xaxis->title->Set(iconv("utf-8","gb2312"," 单 位 ， 元 /月 份 ")); // 定 义 义 轴 输 出 的 值 


Seraph->xaxis->title->SetMargin(10); /定义 冬 轴 输出 的 值 
$eraph->title->SetFont(FF_SIMSUN, FS_ BOLD): /设置 标题 字体 
$graph->yaxis->title->SetFont(FF SIMSUN, FS_BOLD): // 设 置 X 轴 内 容 的 字体 | 
$egraph->xaxis->title->SetFont(FF_SIMSUN, FS_BOLD): 1/ 设置 Y 轴 内 容 的 字体 
S$lineplot->SetColor("blue"); /设置 图 像 颜 色 | 
Slineplot->SetWeight(2); // 设 置 折线 的 宽度 | 
$eraph->StrokeO: // 生 成 图 像 | 
?> | 
技术 要 点 | 


本 实例 通过 Jpgraph 类 库 创建 折线 图 ,分析 2010 年 牛肉 市 场 的 价格 走势 ， 旨 在 突出 如 | 
何在 折线 图 中 输出 格式 化 的 数据 ， 以 及 在 折线 图 的 数据 点 上 添加 标记 。 
(1) 输出 数据 应 用 的 是 value0 对 象 中 的 Show0 方 法 ， 数 据 的 格式 化 应 用 的 是 | 
SetFormat() 方 法 。 | 
SetFormat($aFormat, $aNegFormat) | 
参数 说 明 : 
加 ”$aFormat: 设置 格式 化 的 样式 。 
加 ”$aNegFormat: 设置 negative 的 值 。 | 
(2) 折线 图 中 标记 的 添加 应 用 的 是 图 像 中 的 mark 对 象 的 SetType0 方 法 ,其 参数 值 设 | 
置 标记 的 类 型 。 其 语法 如 下 : | 
SetType($aType, $aFileName, $aScale) | 
加 ”$aType: 设置 标记 的 类 型 。 
回 $aFileName: 插入 图 像 的 名 称 或 者 国家 的 名 称 。 | 
回 ”SaScale， 设置 插入 标记 的 大 小 。 
下 面 列举 了 一 些 SetType0 方 法 中 第 一 个 参数 可 选 的 类 型 : MARK_ SQUARE、 | 
MARK _UTRIANGLE、MARK DTRIANGLE、 MARK DIAMOND、MARK CIRCLE, 这 
些 标记 仅 供 参考 ， 如 果 想 了 解 更 多 内 容 请 参考 Jpgraph 类 库 的 参考 手册 。 | 


实例 187 多 人 饼 形 图 区 块 分 析 2010 年 图 书 销量 


( 实例 位 置 : 配套 资源 \SL\10\187 ) 
实例 说 明 
本 实例 运用 Jpgraph 生成 饼 形 图 ， 对 公司 2010 年 图 书 销量 进行 分 析 ， 其 运行 结果 如 
“283 。 


由 


图 10.16 所 示 。 


| 技术 


本 实例 通过 Jpgraph 类 库 创 建 饼 形 图 , 应 用 饼 形 图 对 象 中 的 Explode0 方 法 完成 对 2010 
FE 各 部 门 图 书 销量 的 分 块 展示 。Explode() 方 法 语法 如 下 : 
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图 10.16 多 饼 形 图 区 块 分 析 2010 年 图 书 销量 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 index.php 文件 ， 设 置 网 页 的 编码 格式 ， 并 通过 include0 语 句 导入 所 需 的 存 
储 在 章 文件 夹 10 下 的 Jpgraph 文件 。 
(2) 应 用 Jpgraph 类 库 中 的 方法 创建 一 个 饼 形 图 ， 对 2010 年 图 书 销量 进行 分 析 。 其 
代码 如 下 : 


<2php 

header ( "Content-type: text/html; charset=UTF-8" ); 
include ("../src/jpgraph.php"); 

include ("../src/jpgraph_pie.php"); 

include ("../src/jpgraph_pie3d.php"); 

$data = array(20.27.45.75.90.30); 

$graph = new PieGraph(500,245,"auto"); 
$graph->SetShadow0; 
$egraph->tabtitle->Set(iconv("utf-8","gb2312",2010 年 图 书 销售 分 析 ) ): 
$graph->tabtitle->SetFont(FF_SIMSUN.FS_BOLD.14): 
$graph->title->SetColor("darkblue"); 
S$egraph->legend->Pos(0.1,0.2); 

$pl = new PiePlot3d($data): 

S$pl->SetTheme("sand"); 

$p1->SetCenter(0.4); 

$p1->SetSize(0.4); 

$p1->SetHeight(20): 

S$p1->SetAngle(45): 
S$p1->Explode(array(5,40,10,30,20)): 
$p1->value->SetFont(FF_ARIAL,FS NORMAL.10): 
$p1->SetLegends(array("ASPNET","C#","JAVA","PHP","VB","VC")): 
$graph->Add($p1): 

S$graph->Stroke0: 

?> 


Pa 


Explode($aExplodeArr) 
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// 设 置 文件 编码 格式 


// 创 建 图 像 

1/ 创建 图 像 阴 影 

// 输 出 标题 

// 设 置 标题 字体 

// 定 义 标题 颜色 

// 控 制 注释 文字 的 位 置 
/创建 图 像 

// 控 制图 像 颜色 

1/ 设置 图 像 位 置 

1/ 设置 图 像 大 小 

1/ 设置 饼 形 图 高 度 
/设置 图 像 倾斜 角度 
/控制 饼 形 图 的 分 割 
/设置 字体 


/添加 数据 
// 生 成 图 像 
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将 饼 形 图 分 割 成 多 个 模块 ， 参 数 $aExplodeArr 是 一 个 数组 ， 根据 数组 元 人数 定 分 | 
割 成 几 块 ， 根 据 数组 元 素 值 定义 分 割 后 模块 与 原 图 像 的 距离 。 


实例 188 ” 缩 略图 艺术 库 


( 实例 位 置 : 配套 资源 \SL\10\188 ) 


实例 说 明 


上 传 图 片 是 一 个 比较 常见 的 功能 , 但 是 在 输出 上 传 图 片 时 可 能 会 遇 到 一 些 问题 。 例如 ，| 
由 于 上 传 图 片 的 大 小 没有 固定 ， 从 而 导致 图 片 在 输出 时 变形 ， 这 是 一 个 很 让 人 伤 脑筋 的 问 | 
题 。 如 果 在 上 传 图 片 时 直接 将 其 生成 一 个 固定 大 小 的 缩 略图 , 并 同时 保存 上 传 的 原始 图 片 ， | 
那么 在 输出 时 就 不 会 有 任何 问题 。 | 

本 实例 就 实现 了 这 样 一 个 功能 ， 在 将 图 片上 传 到 服务 器 的 同时 ， 生 成 图 片 的 缩 略图 ， | 
直接 浏览 图 片 的 缩 略图 .如 果 要 下 载 , 则 下 载 的 仍 是 原始 图 片 。 本 实例 的 运行 效果 如 图 10.17 | 


所 示 。 
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图 10.17 缩 略图 艺术 库 
具体 步骤 如 下 : 


(1) 在 上 传 文件 的 处 理 页 面 index_ok.php 中 ， 包 含 了 一 个 thumbnail.php 文件 ; 二 新， 
定义 上 传 文件 的 类 型 ， 并 重新 指定 上 传 文件 的 存储 位 置 ， 定义 原始 文件 存储 文件 夹 和 缩 略 | 
图 存储 文件 夹 ; 在 通过 move uploaded file0 函数 完成 文件 的 上 传 操作 后 ， 调用 | 
thumbnail.php 文件 中 包含 的 方法 makethumbO 将 上 传 的 图 片 生成 缩 略 图 , 并 添加 文字 水 印 。 
这 是 在 index_ok.php 文件 中 所 作 的 处 理 ， 其 关键 代码 如 下 : 

<?php 

header ( "Content-type: text/html: charset=UTF-8" ); /设置 文件 编码 格式 
include "conn/conn.php": 

include "thumbnail.php"; 
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这 (8_ POST [files] (=") { 
$data = date ( "Y-m-d H:m:s" ); 
function check($var) { // 验 证 数组 的 返回 值 是 否 为 空 
Tetum ($var (= ""); 


} 
Sfiles = array_filter ($_POST ["files"], "check" ); // 去 除数 组 中 空 值 
Sarray = array_filter ( $_FILES ["picture"] ["name"], "check" ); // 去 除数 组 中 空 值 
foreach ( $array as $key => $value ) { /1/ 循 环 读 取 数组 中 数据 
$types = strtolower ( strstr ( $value, '…) ); /截取 上 传 文件 的 后 级 
站 ($types 一 "jpg" || $types 一 ".gif" || $types 一 "png") { /判断 上 传 文件 的 后 绥 是 否 符合 
S$thumbnail = 'thumbnail/; 
$original ='original/: 
$file name =time 0 . $key . strtolower (strstr ( $value, "." ) ); /定义 上 传 文件 名 称 
$path = $original . $file name; // 定 义 原始 文件 的 存储 位 置 
$path thumbnail = $thumbnail . $file name; /定义 缩 略图 的 存储 位 置 
move Uploaded file($_FILES ["picture"] ["tmp_name"] [$key], $path );// 执 行 上 传 操作 
makethumb ( $path, $path_thumbnail, "200", "200", "100", "www.mrbccd.com'" ); 
/生成 缩 略图 


$query = "insert into tb up file (file_test,path thumbnail,data,file name) values 
(‘$path','$path thumbnail','$data','$files[$key])"; 

$result = mysql_query ( $query ); 

echo "<script>alert( 图 片上 传 成 功 ); window.location.href='index.html';</script>"; 


} else { 
echo "上 传 文件 " . $value . "类 型 不 正确 ! "; 


(2) 创建 thumbnail.php 文件 ， 定 义 makethumb() 方 法 ， 完 成 缩 略 图 的 生成 和 水 印 的 
添加 操作 。 自 定义 方法 makethumb() 的 语法 如 下 : 
makethumb($srcFile, $dstFile, $dstW, $dstH., $rate = 100, $markwords = null, $markimage = nul){} 
参数 说 明 : 
$srcFile: 图 片 文件 名 。 
$dstFile: 另存 文件 名 。 
$markwords: 水 印 文字 。 
$markimage: 水 印 图 片 。 
$dstW: 图 片 保存 宽度 。 
$dstH: 图 片 保存 高 度 。 
S$rate: 图 片 保存 品质 ， 默 认 值 100。 
有 关 thumbnail.php 文件 的 完成 代码 请 参考 本 书 配套 资源 。 
技术 要 点 
本 实例 中 重点 讲解 的 是 如 何 生成 图 片 的 缩 略 图 ， 并 为 缩 略 图 添加 水 印 。 其 原理 如 下 : 
“286 
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(1) 通过 GetmmageSize0 函 数 获取 上 传 图 片 的 信息 ， 包 括 大 小 、 类 型 等 信息 ， 并 根据 | 

其 类 型 ， 新 建 一 个 对 应 类 型 的 图 像 。 | 

getimagesize() 函 数 ， 获 取 指 定 图 像 的 大 小 。 语 法 如 下 : 
alTay getimagesize ( string filename [, array &imageinfo] ) 


getimagesize() 函 数 将 测定 任何 GIF、JPG、PNG、SWF、SWC、PSD、TIFF、BMP、 

JIFF、JP2、JPX、JB2、JPC、XBM 或 者 WBMP 图 像 文件 的 大 小 ， 并 返回 图 像 的 尺寸 以 及 | 

文件 类 型 和 一 个 可 以 用 于 普通 HTML 文件 中 <IMG> 标 记 中 的 height/width 文本 字符 串 。 | 
返回 值 是 一 个 具有 四 个 单元 的 数组 : 
索引 0 包含 图 像 宽度 的 像素 值 。 

回 索引 1 包含 图 像 高 度 的 像素 值 。 | 

回 索引 2 是 图 像 类 型 的 标记 : 1= GIF, 2=JPG, 3=PNG, 4=SWF, 5=PSD, 6= | 

BMP, 7 = TIFF(intel byte order), 8 = TIFF(motorola byte order), 9 = JPC, 10= JP2, | 

11=JPX, 12= JB2, 13=SWC, 14=IFF, 15= WBMP, 16= XBM.。 | 

回 ”索引 3 是 文本 字符 串 ， 内 容 为 “height="yyy" width="xxx"”， 可 直接 用 于 IMG 标记 。 | 

如 果 参 数 filename 指定 的 图 像 或 者 其 不 是 有 效 的 图 像 ， 将 返回 FALSE 并 产生 一 条 | 

E_WARNING 级 的 错误 。 | 

(2) 对 上 传 图 片 的 大 小 与 指定 缩 略图 的 大 小 进行 比较 ， 看 其 是 否 需要 创建 缩 略 图 。 

(3) 根据 判断 结果 应 用 imagecopyresampled0) 函 数 重新 生成 新 的 图 像 。 | 

imagecopyresampled0) 函 数 ， 从 原 图 像 中 采样 ， 复 制 部 分 图 像 ， 重 新 生成 图 像 。 语 法 如 下 : | 

bool imagecopyresampled ( resource dst_image, resource sre_image, int dst_x, int dst_y, int sre_x, int 

src_y, int dst_w, int dst_h, int sre_w, int sre_h ) | 

imagecopyresampled0 将 一 幅 图 像 中 的 一 块 正方 形 区 域 复制 到 另 一 个 图 像 中 , 平滑 地 插 | 

入 像素 值 ， 在 减 小 图 像 的 大 小 的 同时 ， 仍 然 保持 了 极 大 的 清晰 度 。 | 

参数 说 明 : 

dst_image: 是 目标 图 像 标 识 符 。 

回 src_image: 是 源 图 像 标识 符 。 | 

如 果 源 图 像 和 目标 图 像 的 宽度 和 高 度 不 同 ， 则 会 进行 相应 的 图 像 收 缩 和 拉 伸 。 坐 标 指 | 

的 是 左上 角 。 本 函数 可 用 来 在 同一 幅 图 内 部 复制 (如 果 dst_image 和 src_image 相同 的 话 ) | 

区 域 ， 但 如 果 区 域 交 迭 的 话 则 结果 不 可 预知 。 | 

如 果 成 功 ， 则 返回 true; 失败 ， 则 返回 false。 


脚下 留神 : 
本 函数 需要 GD 库 2.0.1 或 者 更 高 版 本 的 支持 。 


(4) 为 重新 生成 的 图 像 添 加 水 印 ， 可 以 选择 文字 水 印 或 者 图 像 水 印 。 | 
添加 文字 水 印 应 用 ImageTTFTextO 函 数 ， 如 果 页 面 使 用 的 不 是 UTF-8 编码 ， 那 么 还 要 | 
对 水 印 文字 的 编码 格式 进行 转换 ， 转 换 成 UIF-8 编码 ， 因 为 ImageTTFText0 函 数 只 支持 | 
UTF-8 编码 。 | 
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添加 图 像 水 印 应 用 imagecopy0 函 数 ， 完 成 对 图 像 的 复制 操作 。 


实例 189 通过 图 像 显示 投票 统计 结果 


全 网 | ( 实例 位 置 : 配套 资源 \SL\10\189 ) 
实例 说 明 
| 在 线 调查 中 的 投票 系统 相信 大 家 都 了 解 ， 本 实例 编写 了 一 个 简易 的 投票 系统 ， 并 将 投 
| 票 结果 以 图 像 的 形式 进行 输出 。 运 行 效果 如 图 10.18 所 示 。 
| 我 最 喜爱 的 运动 员 选项 投票 结果 
r Bt 一 = 
® 南宫 一 ==n 
确认 提交 


图 10.18 通过 图 像 显 示 投票 统计 结果 
大 现 过 程 


本 实例 的 文件 架构 如 图 10.19 所 示 。 


品 -om 一 一 一 一 一 一 一 一 一 连接 数据 库 文件 夹 
日 和 一 一 一 一 一 一 一 一 一 Css 样式 文件 夹 
局 inages 一 一 一 一 一 一 一 一 一 一 青 及 图 像 文件 夹 
徊 ! trp 

而 > tm 

入 :tm 

入 4 

若 5. tn 

Gb delete vote. php— 剔除 投票 主题 
Pindexphp 浏览 投票 主题 

L 一 

| 一 一 一 一 一 一 一 提交 投票 和 浏览 投票 结果 
Pjlook_vote_ok php 一 “处理 提交 的 投票 
Pjvote.php 一 一 添加 投票 选项 


图 10.19 投票 系统 的 文件 架构 


| 这 里 重点 介绍 look_vote.php 文件 ， 在 该 文件 中 完成 投票 的 提交 操作 和 投票 结果 的 输 
| 出 。 首 先 ， 根 据 超 链接 传递 的 ID， 查询 出 指定 的 投票 主题 ， 并 计算 出 投票 总 数 。 然 后 ， 创 
| 建 表 单 ， 提 交 投 票选 项 ， 将 数据 提交 到 look vote_ok php 页 进行 处 理 。 最 后 ， 执 行 查询 语 
| 句 ， 从 数据 库 中 查询 出 投票 结果 ， 并 完成 投票 结果 的 输出 。 其 关键 代码 如 下 : 

< 

include_once ("conn/conn.php"); 

if(!$ GET[id]) { 

echo "没有 指定 ID! "; 

exit |); 

}else { 


?> 
/执行 查询 ， 输 出 投票 主题 
<2php 
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$sql = "select* from tb vote where tb vote id='$ GET[id]'": /显示 指定 投票 项 
$result = mysql query ( $sql, $conn ); 
$row = mysql fetch array ( $result ); 
$s = $row [tb vote num]; 
echo "$row[tb_vote_name]l\n"; 
> 
// 创 建 表单 ， 提 交 投 票选 项 
<form action=look_vote_ok.php method=post><input type=hidden name=id value="<?php echo $row 
[tb_vote id]; ?>"><input type=hidden name=v_type value="<?php echo $row [tb_vote_typel; ?>"> 
</form> 
// 输 出 投票 结果 
<2?php 
$sql2 = "select * from tb_vote_record where tb_vote id='$_GET[id]"; 
$result2 = mysql_query ( $sql2, $conn ); 
while ( $rows = mysql fetch array ( $result2 ) ) { 


> 
<tr> 
<td height="25" align="center"> 
<?php 
if ($row [tb_ vote _ type] 一 0) { 
echo "<input type=radio name=r Value=" . $rows [tb_record idq] . ">\n"; 
} else { 
echo "<input type=checkbox name=Ir[] value=" . $rows [tb_record id] . ">\n"; 
} 
?></td> 
<td>&nbsp:<?php echo $rows [tb_record name];: ?></td> 
<td>&nbsp; 
<?php 
if ($rows [tb_record_ num] 一 0) 
$width = 0; 
else 
$width = $rows [tb_record_ num] / $s; 
if ($width != 0) { 
echo "<img sre=" . $rows [tb_record_color] . "bmp width=" . ($width * 20) . " height=10>\n"; 
echo $rows [tb_record num] . "/" . $row [tb_vote_num]:; 
?></td> 
</tr> 
<?php 
?> 
<2php 
上 
?> 
技术 要 点 


投票 系统 包括 : 动态 生成 投票 主题 、 动 态 添加 投票 选项 内 容 、 投 票 主题 管理 和 投票 功 
能 实现 。 这 里 重点 介绍 在 投票 功能 中 如 何以 图 像 的 形式 输出 投票 结果 。 
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在 look_vote.php 文件 中 , 根据 总 的 投票 数 ， 计 算出 每 一 项 所 占 的 比例 ,然后 根据 这 个 
| 比例 值 计算 输出 的 图 像 ， 其 关键 代码 如 下 : 


<?php 
$sql="select * from tb_ vote where tb_vote id-'$ GET[id]": /显示 指定 投票 项 
Sresult=mysql_query($sql,$conn); // 执 行 查询 指定 的 投票 选项 
$row=mysql fetch_array($result); /获取 查询 结果 
$s=$row[tb_vote_num]; /1/ 计 算 总 的 投票 数量 
echo "$row[tb_vote_namel]\n"; /| 输出 投票 选项 的 名 称 
ge 
<?php 
这 $rows[tb record_ num] 一 0) // 判 断 如 果 投 票数 为 0 
$width=0; // 定 义 变量 值 为 0 
else 
$width=$rows[tb_record_num]/$s: // 否 则 ， 根 据 投票 数 和 总 的 投票 数 计算 输出 所 占 比例 
if($width!=0){ // 以 图 像 的 形式 输出 投票 所 占 比 例 


echo "<img sre=".$rows[tb_record_color].".bmp width=".($width*20)." height=10>\n"; 


b 
echo $rows[tb_record_num]."/".$row[tb_vote_num]; /以 数字 输出 投票 数 和 总 的 投票 量 


实例 190 通过 图 像 显 示 密 码 安 全 强度 
( 实例 位 置 配套 资源 \SL\10\190 ) 
实例 说 明 


在 本 实例 中 ， 将 介绍 图 像 的 另 一 项 妙用 ， 通 过 它 来 显示 注册 填写 密码 的 安全 强度 。 运 
行 本 实例 ， 当 在 密码 文本 框 中 输入 一 个 密码 时 ， 光 标 离 开 后 ， 将 自动 判断 这 个 密码 的 安全 
强度 ， 并 以 图 像 的 形式 返回 一 个 判断 结果 ， 运 行 结果 如 图 10.20 所 示 。 


er 全 : 
一 咱 四 一 一 结 竹 加 人 masa 


© http://www.mrbccd.com 一 
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图 10.20 通过 图 像 显 示 密码 安全 强度 
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实现 过 程 


本 实例 完成 一 个 用 户 注册 的 功能 ， 并 且 在 表单 中 通过 JavaScript 脚本 对 提交 的 元 素 进 


行 判断 ， 在 最 终 符合 要 求 后 ， 将 用 户 注册 信息 添加 到 指定 的 数据 表 中 。 


(1) 创建 mdex.php 页 面 ， 完 成 用 户 注册 页 面 和 表单 的 设计 ， 通 过 JavaScript 对 表单 
中 提交 的 值 进行 判断 ， 并 直接 将 判断 的 结果 反馈 到 div 标签 中 ， 最 终 将 表单 中 的 数据 提交 


到 index_ok.php 文件 中 ， 完 成 用 户 注册 的 操作 。 


reg.all)"> 
<tr> 
<td height="30"><div align="right"> 密 码 : </div></td> 


<td height="30" colspan="2" align="left">&nbsp; <input type="password" name="pwd" id="pwd" | 


size="30" class="inputcss" onBlur="chkreginfo(form reg,1)"> <font color="#EF0000">*</font> &nbsp; 
<div id="chknew_pwd" style="color: #FF0000"></div> 
</td> 
</tr> 
<tr> 
<td height="30">&nbsp;</td> 


<td width="150" height="30"><input type="image" src="images/form (2)jpg"> &nbsp; | 


&nbsp;</td> 


style="cursor: hand" /></td> 
</tr> 
</form> 


(2) 创建 JavaScript 脚本 , 编写 checkjjs 脚本 文件 ， 完 成 对 表单 中 提交 的 值 进行 判断 。 
(3) 创建 index_ok.php 文件 ， 获 取 表 单 中 提交 的 数据 ,将 数据 添加 到 指定 的 数据 表 中 。 | 
(4) 创建 conn.php 文件 ， 完 成 MySQL 服务 器 和 MySQL 数据 库 的 连接 操作 ， 并 设置 | 


编码 格式 为 UTF-8。 
技术 要 点 
如 下 : 


意 一 种 ， 那 么 说 明 密 码 安全 强度 差 。 


(2) 对 密码 中 的 值 进行 判断 ， 如 果 包 含 数字 、 英 文字 符 串 或 者 特殊 字符 串 中 的 任意 


两 种 ， 那 么 说 明 密 码 安全 强度 中 。 


(3) 对 密码 中 的 值 进行 判断 ， 如 果 同 时 包含 数字 、 英 文字 符 串 和 特殊 字符 串 ， 那 么 


说 明 密 码 安全 强度 强 。 | 
在 JavaScript 脚本 中 ， 通 过 search0 方 法 调用 正则 表达 式 ， 完 成 对 密码 值 的 判断 ， 其 关 | 
键 代码 如 下 : | 
var pl = (form .pwd.value.search(/[a-zA-2]/)!=-1)?1:0: // 判 断 密 码 中 是 否 包 含 英文 字符 串 
Var p2 = (form.pwd.value.search(/[0-9]/)!=-1)?1:0:; // 判 断 密码 中 是 否 包含 数字 


“294 


<form name="form reg" method="post" action="index_ok.php" onSubmit="return chkreginfo(form_ | 


<td width="343"><img src="images/form.jpg" width="72" height="26" onClick="form reg.resetO" | 


对 密码 的 安全 强度 进行 判断 是 在 JavaScript 脚本 中 应 用 正则 表达 式 来 完成 的 。 其 原理 


(1) 对 密码 中 的 值 进行 判断 ， 如 果 只 包含 数字 、 英 文字 符 串 或 者 特殊 字符 串 中 的 任 
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CD 
让 
varp3 = (form.pwd.value.searchU[^a-zA-Z0-9_]/)=-1)21:0; // 判 断 密码 中 是 否 包含 特殊 字符 
Var p= pl+p2+p3; // 定 义 判断 的 返回 值 
if(p—D{ 
| chknew pwd.innerHTMIL="<img src='images/] 03.jpg>" /输出 密码 安全 强度 差 的 图 像 
侠 内 | jelse if(p—2){ 
~ | chknew_pwd.innerHTMI="<img src='images/2 03.jpg>": ”// 输 出 密码 安全 强度 中 的 图 像 
}else ifp 一 3){ _ 
| chknew_pwdinnerHTML="<img src='images/3_03.jpg>"; ”// 输 出 密码 安全 强度 强 的 图 像 
| } 


实例 191 任意 调整 上 传 图 片 的 大 小 


( 实例 位 置 : 配套 资源 \SL\10\191 ) 


| 图 像 大 小 的 调整 对 于 专业 的 美工 或 者 网 页 设计 者 来 说 不 算 什 么 ， 但 对 于 程序 员 来 说 
| 特别 是 对 那些 不 善于 处 理 图 片 的 程序 员 来 说 ， 是 一 个 非常 头疼 的 问题 。 虽 说 图 片 处 理 不 在 
| 程序 员 的 工作 范围 之 内 ， 但 是 ， 有 些小 问题 还 是 自力 更 生 的 好 。 本 实例 将 介绍 一 种 方法 ， 对 
| 图像 的 大 小 任意 调整 ， 这 是 解决 程序 员 处 理 图 片头 疼 的 一 剂 良 方 。 运行 本 实例 ， 在 上 传 图 片 
| 的 右 侧 ， 选 择 要 调整 图 片 大 小 的 比例 ， 然 后 单 击 下 面 的 按钮 ， 运 行 结果 如 图 10.21 所 示 。 


| 图 10.21 任意 调整 上 传 图 片 的 大 小 

| 实现 过 程 

| 具体 步骤 如 下 ， 

| (1) 创建 一 个 图 片上 传 功能 ， 将 图 片上 传 到 服务 器 指定 的 文件 夹 下 ， 并 通过 文件 系 
| 统 函 数 读 取出 存储 在 指定 目录 下 的 图 片 。 

| (2) 在 图 片 输出 的 同时 ， 在 右 侧 创建 一 个 表单 ， 提 交 图 片 的 存储 位 置 、 名 称 和 要 调 
， 整 的 尺寸 ， 将 数据 提交 到 index_okphp 文件 中 。 

| (3) 创建 index_ok.php 文件 ， 包 含 thumbnail.php 文件 ， 实 例 化 image 类 ， 调 用 其 中 
| 的 thumb() 方 法 ， 将 表单 中 提交 的 数据 作为 参数 ， 完 成 对 图 片 大 小 的 调整 。 其 关键 代码 如 下 : 


<2?php 

这 $_ POST['Submit] 一 "调整 图 像 大 小 7){ 

include("thumbnail php"): /包含 图 像 类 存储 文件 
Simg = new image0: /实例 化 图 像 处 理 类 
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Sreturn=$img->param($ POST[pic_ path])->thumb("Jthumbnail"$ POST['pic name'’], $ POST['pic_ width'], | 

$_POST['pic height'],1): | 
echo "<script>alert( 图 像 大 小 设置 成 功 ! ); window.location.href='index.php';</script>"; 
1 


?> 


(4) 创建 thumbnailphp 文件 ， 编 写 image 类 ， 定 义 thumb0 方 法 ， 根 据 表单 中 提交 的 | 
数据 ， 完 成 图 像 大 小 的 调整 操作 。 其 关键 代码 如 下 : 


// thumb( 新 图 地 址 ， 宽 ,高 , 裁剪， 允许 放大 ) | 
public function thumb($filename, $news_w = 100, $news h= 100, $cut=0, $big = 0) { | 
S$info = $this->getImageInfo ( $this->img ); // 获 取 原 图 信息 | 
if(! empty ( $info [0] )) { | 
S$old_w = $info [0]; 
$old h = Sinfo [1]: 
$new_w = $old w * $news_w; 
$new_ h=$old h* $news h: 
Stype = $info ['type']; 
$ext = $info [ext]: 
unset ( $info ); 
过 ($old_w < $new_h && $old_h < $new_w && ! $big) {// 如 果 原 图 比 缩 略 图 小 并 且 不 允 


许 放 大 
return false; 


} 
if ($cut—1){ // 居 中 裁剪 
$scalel =Iound ( $new_w / $new_h, 2 ); 
$scale2 = round ( $old_w / $old h, 2); 
if($scalel > $scale2) { 
$end h=round ( $old w/ $scalel, 2 ): 
$start h = ($old h- $end hb) /2; 
S$start w= 0; 
Send w= $old_w; 
}else { 
S$end w=round (S$old h* $scalel, 2 ): 
$start Ww = ($old w - $end_ w) /2; 


S$start h = 0; 
$end h= $old h: 
} | 
S$width = $new_w: // 定 义 图 像 宽 | 
Sheight = $new_h; // 定 义 图 像 高 
} | 
$createFun = 'ImageCreateFrom' . $type: // 新 建 图 像 | 


$oldimg = $createFun ( $this->img ): | 
if ($type (= "gif && function exists ('imagecreatetruecolor )) { | 
$newimg = imagecreatetruecolor ( $width, Sheight ); // 创 建新 的 真 彩 图 像 | 
}else{ 
$newimg = imagecreate ( $width, $height ); // 创 建新 的 图 像 
} 
Hf (function exists ( "ImageCopyResampled" )) { 
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Ce 
KC, 
ImageCopyResampled ( $newimg, $oldimg, 0, 0, $start w, $start h, $width, $height, 
$end_w, $end h ); /完成 图 像 的 复制 
} else{ 


TmageCopyResized ( $newimg, $oldimg, 0, 0, $start w, $start h, $width, $height, 
$end_w, $end h); 


上 
$type — )peg && imageinterlace ( $newimg, 1 ); // 对 jpeg 图 形 设置 隔行 扫描 
S$imageFun = 'image' . $type; /生成 图 片 
1@$imageFun ( $newimg, $filename ) && die (' 保 存 失败 !); 
JImageDestroy ( $newimg ); /销毁 图 像 
return $filename; // 返 回 图 像 名 称 
} 
| } 
| 技术 要 点 


任意 调整 上 传 图 片 大 小 方法 实现 的 原理 : 
首先 ， 根据 表单 中 提交 的 值 ， 获 取 指 定 图 片 的 存储 路 径 和 名 称 ， 以 及 它 要 被 调整 的 比例 。 
其 次 ， 应 用 getimagesize0) 函 数 获取 指定 图 片 的 数据 。 
青 次， 定义 thumb0 方 法 ， 根 据 原始 图 片 的 数据 和 提交 的 调整 比例 数据 ， 判 断 是 根据 
比例 缩放 ， 还 是 进行 裁剪 。 
最 后 ， 载 入 原始 图 片 ， 并 定义 新 的 缩 略图 ， 应 用 ImageCopyResampled0 函 数 将 原始 图 
像 复制 到 新 的 缩 略 图 中 ， 并 将 新 的 图 像 存储 到 指定 位 置 。 
(1) imagecopyresampled() 函 数 ， 从 原 图 像 中 采样 ， 复 制 部 分 图 像 ， 重 新 生成 图 像 。 
(2) Imagecopyresized() 函 数 ， 同 样 实现 图 像 的 复制 操作 。 语 法 如 下 : 
bool imagecopyresized ( resource dst_image, resource sre_image, int dst_x, int dst_y, int sre_x, int 
src_y, int dst_w, int dst_h, int sre_w, int src h ) 
(3) imagecopyresized0 将 一 幅 图 像 中 的 一 块 正方 形 区 域 复制 到 另 一 个 图 像 中 。 
参数 说 明 : 
回 dst_ image: 是 目标 图 像 标识 符 。 
回 src_image: 是 源 图 像 标 识 符 。 
如 果 源 图 像 和 目标 图 像 的 宽度 和 高 度 不 同 ， 则 会 进行 相应 的 图 像 收 缩 和 拉 伸 。 坐 标 指 
的 是 左上 角 。 本 函数 可 用 来 在 同一 幅 图 内 部 复制 (如 果 dst_image 和 src_image 相同 的 话 ) 
区 域 ， 如 果 区 域 交 迭 ， 则 结果 不 可 预知 。 


脚下 留神 : 

因为 调 色 板 图 像 的 限制 (255+1 种 颜色 )， 而 重新 采样 或 过 滤 图 像 通常 需要 多 于 255 
种 颜色 ， 所 以 计算 新 的 被 重新 采样 的 像素 及 其 颜色 时 采用 了 一 种 近似 值 。 对 调 色 板 图 像 尝 
试 分 配 一 个 新 颜色 时 ， 如 果 失 败 ， 则 选择 计算 结果 最 接近 ( 理论 上 ) 的 颜色 。 这 并 不 是 视 
觉 上 最 接近 的 颜色 。 这 可 能 会 产生 怪异 的 结果 ， 例 如 ， 空 白 (或 者 视觉 上 是 空白 ) 的 图 像 。 
要 跳 过 这 个 问题 , 请 使 用 真 彩色 图 像 作为 目标 图 像 ， 例 如 ,使 用 imagecreatetruecolor(O 函 数 
创建 的 图 像 。 
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文件 目录 处 理 


本 章 读 者 可 以 学 到 如 下 实例 : 

WI 实例 192 文件 操作 汇总 

MH 实例 193 文件 类 型 检测 

WI 实例 194 删除 指定 目录 下 的 所 有 ini 文件 

WI 实例 195 重新 定义 目录 的 名 称 

WI 实例 196 获取 磁盘 分 区 的 大 小 

PH 实例 197 遍历 指定 目录 下 的 所 有 文件 

WI 实例 198 可 以 屏蔽 刷新 功能 的 文本 计数 器 

WI 实例 199 从 文本 文件 读 取 注 册 服 务 条 款 

PH 实例 200 遍历 、 删 除 指定 文件 目录 下 的 所 有 文件 
WI 实例 201 文件 属性 分 析 

WI 实例 202 将 文本 文件 中 的 内 容 存 储 到 数据 库 中 
MH 实例 203 判断 文件 是 否 被 改动 

”实例 204 目录 操作 汇总 


需 
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实例 192 文件 操作 汇总 
( 实例 位 置 配套 资源 \SL\11\192 视频 位 置 配套 资源 \SP\11\192 ) 


实例 说 明 

| 为 了 便于 对 网 站 的 管理 、 维 护 和 更 新 ， 应 该 设计 一 个 能 够 对 文件 进行 操作 的 模块 ， 实 
| 现 对 文件 的 创建 、 复 制 、 移 动 和 删除 的 操作 ,这样 能 够 给 网 站 的 管理 工作 提供 很 大 的 方便 ， 
| 不 再 因为 要 修改 某 个 文件 而 要 登录 到 FTP 中 , 通过 下 载 或 上 传 实现 文件 的 更 新 , 这 种 方案 
”能 够 节省 很 多 的 时 间 。 运 行 本 实例 ， 实 现 对 指定 文件 的 创建 、 复 制 、 移 动 和 删除 的 操作 ， 
| 只 要 在 文本 框 中 和 输入 要 复制 文件 的 路 径 和 名 称 ， 在 对 应 的 文本 框 中 输入 指定 文件 要 复制 到 
| 的 具体 文件 夹 的 路 径 和 名 称 〈 包 括 指定 文件 的 名 称 )， 然 后 单 击 “ 提 交 ” 按 钮 即 可 ， 运 行 
| 结果 如 图 11.1 所 示 。 


图 11.1 文件 操作 汇总 
现 过 程 
有 具体 步骤 如 下 : 
| (1) 创建 index.php 文件 。 首 先 ， 设 计 文件 汇总 的 页 面 。 然后。 应 用 switch 语句 设计 
| 一 个 简单 的 框架 ， 完 成 复制 、 移 动 、 创 建 和 删除 操作 之 间 的 切换 。 最 后 ， 编 写 PHP 脚本 ， 
| 根据 表单 中 提交 的 数据 ， 执 行 不 同 的 文件 操作 。 其 关键 代码 如 下 : 


| <2php 
| iftisset($_GET['operate]){ // 获 取 超 链接 参数 
$operate=$_GET['operate']: /定义 参数 变量 值 
}else{ 
$operate=""; 
} 
switch ($operate) { // 实 现 不 同 操作 之 间 的 转换 
case "found" : 


include ("found .php"): 
break: 


Case "copy" : 
include ("copy.php"): 
break; 
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case "move" : 
include ("move.php"); 
break; 

case "delete" : 
include ("delete.php"); 
break: 


default : 
include ("copy.php"); 


} | 
?> 
<?php | 
让 (9_ POST [Submit] 一 "复制 ") { // 判 断 用 户 是 否 执 行 复制 操作 
$copy = iconv ( "utf-8", "gb2312", $_ POST [copys] ); /| 转换 获取 名 称 的 编码 格式 
$copys2 = iconv ( "utf-8", "gb2312", $_POST ['copys2'] ); 
if (copy ( $copy, $copys2 )) { // 判 断 是 否 复制 成 功 
echo "<script>alert(' 复 制 成 功 !1);</script>"; // 弹 出 复制 成 功 对 话 框 
}else { 
echo "<script>alert(' 复 制 失败 !1");</script>"; // 弹 出 复制 失败 对 话 框 


; 
} 
1/ 省略 了 部 分 代码 


> 


(2) 分 别 创建 copy.php、delete.php、found.php 和 move.php 文件 ， 完 成 不 同 操 作 的 执 | 
行 页 面 。copy.php 文件 的 代码 如 下 : 


<table width="466" height="112" border="0" cellpadding="0" cellspacing="0"> 
<form name="forml1" method="post" action=""> 
<tr> 
<td width="111" rowspan="2" align="center"> 复 制 文件 </td> 
<td width="67" align="right" valign="bottom">copy: </td> 
<td width="229" height="39" valign="bottom"><input name="copys" 
type="text" id="copys" size="22"></td> 
<td width="126" rowspan="2" align="left" valign="middle"><input 
type="submit" name="Submit" value=" 复 制 "></td> 
</tr> 
<tr> 
<td align="right" valign="top">affix: </td> | 
<td height="41" valign="top"><input name="copys2" type="text" 
id="copys2" size="22"></td> | 
</tr> 
<tr> | 
<td colspan="4" align="center"> 例 如 : F:\xampp\htdocs\MR\05\012\test.txt</td> | 
</tr> | 
</form> | 
</table> | 


技术 要 点 | 
本 实例 主要 应 用 fopen0、copy0、rename0 和 unlink0O4 个 函数 完成 文件 的 创建 、 复 制 、 | 
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&%, 


| 移动 和 删除 操作 。 


(1) fopen0 函 数 。 
fopen0 函 数 用 于 打开 文件 或 者 URL。 函 数 的 语法 如 下 : 
int fopen(string filename, string mode): 


创建 文件 主要 应 用 fopen0 函 数 的 mode 参数 ，mode 参数 的 可 选 值 如 下 : 
回 'w' 写 入 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 零 。 如 果 文 件 不 存 
在 ， 则 进行 创建 。 
回 "w+' 读 写 方式 打开 ， 将 文件 指针 指向 文件 头 并 将 文件 大 小 截 为 零 。 如 果 文 件 不 
存在 ， 则 进行 创建 。 
回 'a' 写 入 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文件 不 存在 ， 则 进行 创建 。 
回 'at' 读 写 方式 打开 ， 将 文件 指针 指向 文件 末尾 。 如 果 文 件 不 存在 ， 则 进行 创建 。 
(2) copy0 函 数 。 
copy0 函 数 主要 用 于 复制 文件 。 函 数 的 语法 如 下 : 
int copy(string source, string dest); 
将 文件 从 source 复制 到 dest。 如 果 成 功 则 返回 trtme， 否 则 返回 false。 
(3) rename() 函 数 。 
rename() 函 数 主要 用 于 文件 重 命名 。 函 数 的 语法 如 下 : 
bool rename(string oldname,newname); 
本 函数 将 oldname 重 命 名 为 newname， 成 功 则 返回 ttme， 耕 则 返回 false。 
(4) unlink0) 函 数 。 
unlinkO 函 数 主要 用 于 删除 文件 。 函 数 的 语法 如 下 : 
bool unlink(string filename): 


本 函数 用 于 删除 文件 。 如 果 文 件 删 除 成 功 则 返回 ve， 否则 返回 false。 


| 多 学 两 招 : 


在 应 用 文件 操作 函数 执行 文件 的 创建 、 移 动 、 复 制 和 删除 操作 时 ， 由 于 实例 的 页 面 纺 


| 码 格 式 是 UTF-8， 所 以 ， 从 表单 中 获取 的 元 素 值 ， 不 能 够 直接 应 用 到 文件 操作 画 数 中 ， 必 
| 须 对 元 素 值 进行 编码 转换 ， 由 UTF-8 编码 转换 为 GB2312 编码 ， 否 则 文件 操作 函数 不 能 够 


实例 193 文件 类 型 检测 
(实例 位 置 : 配套 资源 \SL\11\193 ) 
| 实例 说 明 


在 开发 程序 的 过 程 中 ， 很 多 时 候 都 需要 获取 到 文件 的 后 绥 名 ， 并 根据 后 绥 名 作出 一 些 
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判断 。 那 么 如 何 才 能 获取 到 文件 的 后 级 名 称 呢 ?在 
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本 实例 中 将 对 这 个 问题 进行 解答 。 运 行 本 实例 ， 将 名 一 个 此 TA 


检测 表单 中 提交 文件 的 后 级 ， 并 根据 后 缀 名 称 ， 作 
出 相应 的 判断 。 其 运行 结果 如 图 11.2 所 示 。 
实现 过 程 

具体 步骤 如 下 : 

(1) 创建 名 称 为 index 的 PHP 文件 。 

(2) 添加 表单 ， 设 置 文件 域 、 提 交 按 钮 ， 使 用 POST 
form-data"， 将 数据 提交 到 本 页 。 

(3) 通过 $_FILES 获取 上 传 文件 的 相关 信息 。 


连 择 上 作文 件 : [CDocuments and Sertinc 区 


文件 类型: chm 上 传 成 功 ， 大 小 为 :153557 


Copyright © 1999-2010 吉林 省 明日 科技 有 限 公司 


图 11.2 文件 类 型 检测 


方法 ， 设 置 enctype="multipart/ 


(4) 应 用 is_dir0 函 数 判 断 指 定 的 服务 器 文件 夹 是 否 存在 ， 如 果 不 存在 则 应 用 au | 


函数 创建 文件 夹 。 


(5) 应 用 is_uploaded file0 函 数 判 断 文件 是 否 是 HITPPOST 上 传 。 
(6) 获取 上 传 文件 名 称 的 后 级 ， 根 据 后 级 的 不 同 ， 定 义 不 同 的 存储 路 径 。 
(7) 应 用 move_uploaded_file(0) 函 数 执行 文件 上 传 的 操作 。 


其 中 index.php 文件 的 关键 代码 如 下 : 


<?php 
if(! empty ($_FILES [up_picture'] [name] )) { 
if ($_FILES [up_picture] [error]> 0) { 
echo "上 传 错 误 :"; 
switch ($_FILES [up_picture'] [error]) { 
casel: 


/判断 上 传 内 容 是 否 为 空 
// 判 断 文 件 是 否 可 以 上 传 到 服务 器 


// 判 断 上 传 错误 代码 
/根据 错误 代码 输出 错误 提示 


echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 


break; 

case2 : 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break: 

case3 : 
echo "上 传 文件 不 全 "; 
break: 

case 4: 
echo "没有 上 传 文件 "; 
break:; 

} 


} else { 
这 (is dir("./txt")) { 
mkdir ("./txt/" ); 
} 
这 (is dir("./pic™")) { 
mkdir ( "./pic/" ); 
} 
if(!lis dir("./fla™")) { 
*。299。 


// 判 断 指定 目录 是 否 存 在 
/创建 目录 


// 浏 断 指 定 目录 是 否 存在 
/创建 目录 


// 判 断 指定 目录 是 否 存 在 
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mkdir ("./aa/"): /创建 目录 


} 
if(!empty($_POST["submitvalue"])){ 
这 (is_ uploaded file ($_FILES [up_picture] [tmp name] )) { /判断 文件 是 否 是 HITPPPOST 上 传 
$type=$ FILES [up_picture] [name']:; /获取 上 传 文件 的 名 称 
$types = strtolower ( strstr ( $type, '… ) ); // 获 取 上 传 文件 的 后 级 
if ($types =— "txt" | S$tyles —".doc") { 
$path ='./txt/ . time () . strstr ( $_FILES [up_picture'] [name'],…): // 定 义 上 传 文件 名 称 和 存 


储 位 置 
} elseif ($types — "jpg" || $tyles 一 "Si | $tyles — ".bmp") { 
| $path = pic/ .time 0 . strstr ( $_FILES [up _picture] [name],'…) 六 /定义 上 传 文件 名 称 和 存 
| 储 位 置 } else{ 
| /定义 上 传 文件 名 称 和 存储 位 置 
$path = '/fla/ . time () . strstr ( $_FILES [up_picture] [mame'],'…); 
if (! move uploaded file ($_FILES [up picture'] [tmp_name'], $path )) { /执行 上 传 操 作 
echo "上 传 失败 ! "; 
}else { 
echo "文件 类 型 : ". $types . "上传 成 功 ， 大 小 为 : ".$_FILES [up_picture'] ['size']; 
} else { 
echo "上 传 文件 :" . $_FILES [up_pictute'] [name'] . "不 合法 ! "; 
} 
} 
> 


| 脚下 留神 : 


处 理 页 为 了 判断 用 户 是 否 已 经 执行 上 传 操作 ， 在 <form> 表 单 中 添加 一 个 名 称 为 


submitvalue 的 隐藏 域 。 并 通过 if(llempty($ POST["submitvalue"])) 语 名 判断 传递 的 
| submitvalue 值 是 否 存 在 。 如 果 该 传递 值 为 空 则 没有 执行 上 传 操作 ， 反 之 则 执行 了 。 如 不 添 
| 加 该 语句 则 有 可 能 会 导致 系统 报错 。 


在 本 实例 中 应 用 move_uploaded_file0 函 数 实现 文件 上 传 的 操作 , 并 根据 文件 的 后 绥 进 


行 判 断 ， 将 不 同类 型 的 文件 存储 在 不 同 的 服务 器 文件 夹 下 。 


获取 上 传 文件 的 后 级 ， 首 先 ， 应 用 $_FILES 全 局 变量 获取 上 传 文件 的 名 称 。 然 后 ， 应 
用 strsr0 函 数 对 上 传 文件 的 名 称 进行 截取 ， 截 取 字 符 串 中 “.” 后 的 所 有 字符 串 。 最 后 ， 应 
用 strtolower0 函 数 将 字符 串 转 换 成 小 写 。 
strstr0) 函 数 ， 获 取 一 个 指定 字符 串 在 另 一 个 字符 串 中 首次 出 现 的 位 置 到 后 者 末尾 的 子 
字符 串 。 语 法 如 下 : 
string strstr ( string haystack, string needle) 


参数 说 明 : 
回 ”haystack: 必 选 参数 ， 指 定 从 哪个 字符 串 中 进行 搜索 。 
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needle: 必 选 参数 ， 指 定 搜索 的 对 象 。 如 果 该 参数 是 
个 数值 的 ASCII 值 相 匹配 的 字符 。 
如 果 执 行 成 功 ， 则 返回 剩余 字符 串 〈 存 在 相 匹配 的 字符 ); 如 果 没 役 有 找到 相 匹配 的 字 | 
符 ， 则 返回 false。 | 


一 全 人, 和 公交 扫 过 与 这 | 


多 学 两 招 : 
文件 后 缓 的 获取 可 以 应 用 到 很 多 地 方 ， 最 为 常用 的 就 是 通过 它 来 控制 上 传 文件 的 类 | 
型 ; 还 有 在 文件 的 读 取 中 ， 判 断 哪些 文件 可 以 读 取 ， 哪 些 不 可 以 读 取 。 | 


实例 194 删除 指定 目录 下 的 所 有 ini 文 件 


( 实例 位 置 : 配套 资源 \SL\11\194 视频 位 置 配套 资源 \SP\11\194 ) 


实例 说 明 
在 文件 操作 汇总 中 已 介绍 过 删除 
» a i i 当 曾 目 好 :FAFPScriwwwWMRO4023 
指定 目录 下 所 有 文件 的 操作 , 在 本 实例 5 在 B 夫人 FM 则 人 
、 最。 2n00MOB1219 0 了 
中 , 将 完成 一 个 更 加 有 具体 的 操作 ,删除 HB 录 。。 目 杂 201606300105 才 201006300105 Wt 
a a nipap 36 a160707031219 al00707032944 ety 
指 定 日 录 | 的 所 有 1n1 文件 o 其 运行 结 Re 713 007.0 031219 D1007.01 0006.28 rr 
3 look fephp 8W6 2010.07.-07031219 D10-07-070325:465 leok fie php 
果 如 图 11.3 所 示 。 人 
xf。 20100700032643 O10.0707032644 Wt 
实 现 过 程 pp 0 oonm0265 D000 EL ] 
到 AL cog 让 6 errved 2010 吉 条 省 时 有 限 人 司 
具体 步骤 如 下 : 


(1) 本 实例 的 创建 过 程 与 遍历 、 图 11.3 删除 指定 目录 下 的 所 有 ini 文件 
删除 指定 目录 下 的 所 有 文件 是 基本 相 
同 的 ， 在 index.php 文件 中 的 不 同 之 处 已 经 在 关键 技术 中 给 出 ， 这 里 不 再 袭 述 。 | 
(2) 创建 look file php 文件 , 将 获取 文件 名 称 的 编码 格式 进行 转换 ,然后 循环 读 取 文 | 

件 中 的 信 wt 最 后 将 特殊 字符 转换 后 的 内 容 输 出 ， 完 成 对 “.INI” 后 缀 文件 的 读 取 操作 。 | 
其 代码 如 

<?php 

$catalog = iconv ( "utf-8", "gb2312", urldecode ($_GET [catalog] ) ); 

$filename = iconv ( "utf-8", "gb2312", urldecode ( $_GET [filename'] ) ); $type = 
"gb2312", urldecode ($_GET [type])); /获取 文件 的 信息 ， 设 置 编码 


iconv ( "utf-8", | 


Sarr = file ( $catalog . "\" . $filename ); /1/ 读 取 文 件 

foreach ( $arr as $value ) { 1/ 循环 输出 文件 内 容 
$value = htmlentities ( $value, ENT_COMPAT, "UTF-8" ); /| 特殊 字符 的 转换 
echo $value . "<br>": /| 输出 内 容 

b 

> 


(3) 创建 delete php 文件 ， 当 用 户 在 单 击 首页 列表 中 文件 名 所 对 应 的 “删除 ” 超 链 接 ，| 
将 完成 对 指定 文件 的 删除 操作 。 | 
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| 技术 要 点 


有 关 目 录 、 文件 的 删除 方法 已 经 在 前 面 实例 文件 操作 汇总 中 讲解 过 , 这 里 就 不 再 歼 述 。 
而 要 删除 指定 目录 下 的 特定 格式 文件 ， 其 实现 的 原理 与 删除 所 有 文件 相同 ， 只 是 在 创建 删 
除 链接 前 需要 对 文件 的 格式 进行 判断 ， 如 果 文 件 的 格式 是 “.INI” 类 型 ， 那 么 就 输出 删除 
的 超 链 接 ， 否 则 将 直接 输出 文件 的 名 称 。 其 关键 代码 如 下 : 

$catalog = getcwd 0 . "\\$gain_directory"; // 子 目录 
$ext = substr ( $gain_directory, strrpos ( $gain_directory, "." ) ); // 获 取 文 件 的 后 缀 
/判断 如 果 文 件 的 后 绥 是 .ini， 哪 么 则 创建 删除 超 链 接 
if (strtoupper ($ext )—".INI") { // 判 断 获 取 文 件 名 称 后 级 是 否 为 “.INI” 
echo "<a href='delete.php?catalog=".urlencode($catalog)."&filename=" . urlencode(getcwd ()) . " 
title=' 删 除 目录 或 者 文件 ,> 删除 </a>"; 


} else{ /如 果 文 件 的 后 缀 不 是 .ini， 则 直接 输出 文件 名 称 
echo iconv ( "gb2312", "utf-8", $gain_directory ); // 输 出 转换 编码 格式 后 的 文件 名 
) 
多 学 两 招 : 


在 进行 程序 开发 的 过 程 中 ， 要 学 会 合理 地 运用 自己 的 编程 资源 。 开 发 的 功能 模块 要 具 
有 重用 价值 ， 一 个 好 的 功能 模块 ， 不 只 是 在 一 个 程序 中 可 以 使 用 。 诸 如 数据 库 的 连接 、 操 
作 方法 以 及 分 页 技术 一 次 开发 后 ， 将 会 在 很 多 的 程序 中 使 用 ， 避 免 对 类 似 的 程序 进行 重复 
开发 ， 浪 费 不 必要 的 时 间 。 

作为 一 个 程序 员 ， 不 只 要 每 次 在 开发 时 都 考虑 新 的 功能 、 新 的 技术 ， 更 重要 的 是 充分 


运用 已 有 资源 ， 既 可 以 提高 程序 的 开发 效率 ， 又 可 以 避免 开发 新 技术 产生 的 一 些 问题 。 


实例 195 重新 定义 目录 的 名 称 


( 实例 位 置 : 配套 资源 \SL\11\195 ) 


实例 说 明 
在 对 网 站 进行 管理 和 维护 的 过 程 中 ， 
经 常会 修改 文件 夹 的 名 称 ， 它 也 是 目录 的 
一 项 基本 操作 。 本 实例 中 将 介绍 更 新 目录 
名 称 的 方法 。 运行 本 实例 ， 单 击 当 前 目录 原 目录 名 称 : |F-WAppSerwwwwNMRWD4WO31\ 新 建文 件 夫 EE 
中 文件 夹 后 的 “ 重 命名 ” 超 链 接 ， 将 进入 新 目录 名 各 :FWApPSemwwwMRA 3 人 piie | [EEC 
到 如 图 11.4 所 示 的 页 面 ， 在 这 个 页 面 中 完 
成 对 指定 目录 的 重 命名 。 图 11.4 重新 定义 目录 的 名 称 


实现 过 程 
具体 步骤 如 下 : 
(1) 创建 index.php 文件 。 输 出 当前 目录 的 文件 和 目录 信息 ， 并 且 为 输出 的 目录 创建 


1 Caopy8iahts © reserved 2010 吉林 省 明日 科技 有 限 公司 
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jh 
哪 


命名 ”的 超 链 接 ， 其 传递 的 参数 是 指定 目录 的 存储 位 置 和 当前 目录 的 位 置 。 其 关键 代 


<table width="650" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td width="50" height="23">&nbsp;</td> 


<td width="450"><span class="STYLE1"> 当 前 目录 : <?php echo getcwd 0:9></span></td> | 


</tr> 
<2php 
$lookdir = getcwd 0: // 获 得 当前 脚本 目录 
$i= 0; 
if (is_dir ( $lookdir )) { // 检 测 是 否 是 合法 目录 
if ($opendir = opendir ( $lookdir )) { // 打 开 目 录 
while ( $li=readdir( $opendir )) { ”// 读 取 目 录 
> 
<tr> 
<td height="23">&nbsp:</td> 
<td> 
<?php 
$i +H; /执行 变量 $i 自 增 操 作 
echo " $i: " . iconv ( "gb2312", "utf-8", $1i); // 转 换 编 码 格式 
?> 
</td> 
<td> 
<2php 
if ($i=""| $="..") { 1/ 判断 变量 $li 是 否 为 “.” 或 者 “..” 
echo "&nbsp:&nbsp:": 
} elseif (filetype ( $1i ) =— "file") { // 否 则 判断 变量 $li 是 否 为 文件 
echo "&nbsp;&nbsp;"; 
Delsef 
Scata = getcwd 0 ."\" . iconv ( "gb2312", "utf-8", $1i ); 
> 


<a href="rename.php?catalog=<?php echo urlencode ( $cata ); ?>&dir name=<?php echo 
urlencode ( getcwd 0 ):2>"title=" 更 新 目录 名 称 " target=" blank"> 重 命名 </a> 


<?php } ?> 
</td> 

</tr> 
Php 
</table> 


(2) 创建 rename.php 文件 ， 根 据 超 链 接 传 递 的 参数 值 ， 创 建 form 表单 ， 完 成 目录 的 
重新 命名 提交 ， 并 且 在 rename.php 文件 中 完成 重 命名 的 操作 。 其 关键 代码 如 下 : 
<2php 
if(isset($_POST['Submit])){ /判断 用 户 是 否 执行 提交 操作 
让 ($_POST['Submit] 一 "提交 ") { 
$old_name=iconv("utf-8","gb2312",$_POST['old name']): /获取 原始 目录 名 称 
$new_name=iconv("utf-8","gb2312",$_POST['new_name'"])); /获取 新 目录 名 称 
if (file exists ($old name )) { 
if (rename ( $old name, $new name )) { // 把 原 目录 重新 命名 
echo "<script>alert(' 目 录 重 命名 成 功 ! ); window.location.href "index.php';</script>"; 
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| yelse{ 
echo "<script>alert( 目 录 重 命名 失败 !"); window.location href~'Tename.php';</script>"; 
| } 
| } else { 

食 扩 | echo "<script>alert( 目录 不 存在 ! ); window.location.href='index.php';</script>"; 

ev | } 

oa 

1 


| 链接 的 参数 向 下 一 个 页 面 中 传递 值 时 ， 最 佳 的 方法 就 是 应 用 urlencode0 函 数 对 参数 值 

| 进行 编码 ， 其 最 大 的 优点 就 是 避免 传递 中 文字 符 串 或 者 空格 时 出 现 乱码 ， 同 时 还 隐藏 了 传 

| 递 的 参数 值 ， 有 一 定 的 保护 作用 。 

| 技术 要 点 

目录 的 重 命名 同样 应 用 的 是 rename0 函 数 ， 其 语法 结构 如 下 : 
bool rename ( string oldname, string newname [, resource context] ) 


该 函数 尝试 把 oldname 重 命名 为 newname。 如 果 成 功 则 返回 tue， 失 败 则 返回 false。 


| 多 学 两 招 : 

| ”在 通过 超 链接 的 参数 向 下 一 个 页 面 中 传递 值 时 ， 最 佳 的 方法 就 是 应 用 urlencode0 函 数 
| 对 参数 值 进行 编码 ， 其 最 大 的 优点 就 是 避免 传递 中 文字 符 事 或 者 空格 时 出 现 乱码 ， 同 时 还 
| 隐藏 了 传递 的 参数 值 ， 有 一 定 的 保护 作用 。 


实例 196 获取 磁盘 分 区 的 大 小 


( 实例 位 置 配套 资源 \SL\11\196 ) 


| 实例 说 明 
| 通过 文件 系统 函数 不 但 可 以 对 目 
| 录 、 文 件 进行 操作 ， 获 取 目录 文件 的 相 
| 关 信 息 ， 而 且 可 以 获取 到 磁盘 分 区 的 大 
| 小 。 运 行 本 实例 ， 将 根据 文本 框 提交 的 


EE : [一 至 
| 目录 ， 获 取 到 该 目录 所 在 磁盘 分 区 的 大 a 
| 小 ， 以 及 该 目录 下 的 所 有 文件 。 其 运行 ee Rt no a es 
| 结果 如 图 11.5 所 示 。 2 
| :这 可 
| 实现 过 程 i 
! 如 1 CopyRights © reserved 2010 吉林 省 明日 科技 有 限 公司 
具体 步骤 如 下 : 
(1) 创建 index.php 文件 。 图 11.5 获取 磁盘 分 区 的 大 小 


(2) 添加 表单 ， 设 置 文本 框 、 提 交 


按钮 ， 使 用 POST 方法 ， 将 数据 提交 到 本 页 。 
(3) 通过 $ POST 获取 表单 提交 的 目录 路 径 , 首先 , 判断 获 取 的 目录 是 否 合理 。 然 后 ， 


通过 iconvO 函 数 对 获取 的 字符 串 进行 编码 转换 。 接 着 ， 对 获取 的 字符 串 进行 截取 ， 获 取 该 | 
目录 所 在 的 磁盘 分 区 ， 并 应 用 disk_total_space() 函 数 获取 磁盘 分 区 的 大 小 。 最 后 ， 应 用 | 


opendir() 和 readdir0) 函 数 读 取 提 交 目 录 下 的 内 容 。 
index.php 的 关键 代码 如 下 : 
<2php 
if (isset($ POST [Submit])){ // 判 断 用 户 是 否 执 行 提交 操作 
if($_ POST [file name'] (= "" && is file ($ POST [file name'] ) 一 false) { 
$file name =iconv ( "utf-8", "gb2312", $ POST ['file name'] ); /编码 格式 转换 


if (file exists ( $file name )) { // 判 断 目 录 是 否 存 在 
Slen = strripos ( $file name, ":" ); // 截 取 字 符 串 
S$dir = substr ( $file name, 0, $len + 1 ): /获取 提交 目录 所 在 磁盘 
Sfilesize z=disk total space ( $dir ): // 获 取 目 录 总 大 小 
$filesize z=number format($filesize z/(1024*1024*1024),2,".","); /数字 的 格式 化 
Sfilesize s=disk free space ( $dir ): // 获 取 磁 盘 剩 余 空 间 


$filesize_s=number format($filesize_s/(1024*1024*1024),2,".",""); // 字 节 的 格式 化 

echo "本 地 磁盘 (" . $dir .") 总 大 小 : ". $filesize z."” GB &nbsp; 可 用 空间 : 
" .$filesize_s." GB <br><br>"; 

echo $_POST ['file name'] ." 目录 下 的 内 容 : ". "<br>"; 


$i=0; 
S$list = opendir ( $file name ); /打开 目录 
while ( $read_ list= readdir ( $list ) ) { // 读 取 目 录 
$i 二 
echo " $i: " . iconv ( "gb2312", "utf-8", Sread list ) . " <br> "; /输出 目录 中 的 内 容 
} 
closedir ( $list ); /关闭 目录 
}else{ 
echo "<script>alert(' 目录 不 存在 ! ");</script>"; // 提 示 用 户 目录 不 存在 
} 
}else { 
echo "<script>alert( 请 输入 正确 的 目录 路 径 ! );</script>"， // 提 示 用 户 输入 正确 路 径 
} 
! 
?> 
技术 要 点 


获取 磁盘 分 区 的 大 小 应 用 的 是 disk_total_space0 函 数 ; 获取 磁盘 分 区 的 剩余 空间 应 用 
的 是 disk_free_space() 函 数 。 
disk_total_space() 函 数 ， 获 取 一 个 目录 的 磁盘 总 大 小 ， 语 法 如 下 : 
float disk total_ space ( string directory ) 
该 函数 根据 参数 directory 提供 的 一 个 目录 字符 串 , 返回 相应 的 文件 系统 或 磁盘 分 区 的 
所 有 字 节 数 。 
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disk_free_space0) 函 数 ， 获 取 一 个 目录 的 可 用 空间 ， 语 法 如 下 : 
float disk_free_space(string directory) 
参数 directory 用 于 指定 文件 系统 或 磁盘 分 区 。 
多 学 两 招 ; 
strripos(O) 函 数 ， 判 断 指定 字符 串 在 另 一 字符 串 中 最 后 出 现 的 位 置 。 
| 通过 本 函数 可 以 获取 到 指定 字符 串 A 在 另 一 字符 串 B 中 最 后 出 现 的 位 置 ， 其 返回 值 
| 为 int 型 ， 根 据 这 个 返回 值 就 可 以 对 字符 串 B 以 字符 串 A 为 分 隔 点 进行 截取 ， 在 执行 截取 
| 的 操作 时 需要 应 用 到 substrO 函 数 。 


实例 197 遍历 指定 目录 下 的 所 有 文件 


(实例 位 置 : 配套 资源 \SL\11\197 ) 


| 在 网 站 的 后 台 管 理 系统 中 ， 经 常 需要 对 网 站 服务 器 中 的 文件 进行 管理 和 维护 ， 有 时 需 
| 要 添加 一 个 文件 夹 或 删除 某 个 文件 夹 

| 或 者 文件 ,为 了 更 好 地 查看 到 这 些 文件 @ 2 2 
| 或 者 文件 夹 , 最 好 的 方法 就 是 创建 一 个 AV 


| 文件 查询 系统 , 通过 它 可 以 查看 到 指定 a a 
| 文件 夹 下 的 所 有 文件 。 运行 本 实例 , 在 

| 文本 框 中 输入 一 个 指定 的 文件 夹 , 单 击 ss 

| “提交 ”按钮 ， 如 果 该 文件 夹 存在 ， 就 ER ET 
| 可 以 显示 出 该 文件 夹 下 包括 的 所 有 文 图 11.6 遍历 指定 目录 下 的 所 有 文件 

| 件 ， 运 行 结果 如 图 11.6 所 示 。 

| 实现 过 程 

| 具体 步 又 如 下 : 

| (1) 创建 index.php 文件 。 添 加 一 个 表单 ， 定 义 表单 元 素 ， 通 过 POST 方式 提交 目录 
| 的 路 径 。 


| (2) 在 indexphp 中 ， 判 断 提 交 的 目录 路 径 是 否 为 空 ， 如 果 不 为 空 ， 则 打开 目录 ， 读 取 
| 目录 中 的 文件 ,并 输出 读 取 到 的 文件 ， 关闭 目录 ; 否则 , 输出 目录 不 存在 。 其 关键 代码 如 下 : 


<2php 
iflisset($_POST['Submit])){ /判断 用 户 是 否 执行 提交 操作 
这 !file_exists ( $look file )){ /检测 指定 的 目录 是 否 存在 
print $look file." 目 录 不 存在 !" ; 
jelse{ 
$i=0; 
if( is_dir ( $look file )){ /检测 是 否 是 合法 目录 
if ($list= opendir ( $look file )){ /打开 目录 
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while ($read list = readdir( $list )){ // 读 取 目 录 
3 
echo " $i: ".iconv("gb2312","utf-8",$read list)." <br> " ; // 输 出 目录 中 的 内 容 
} 
} 
! 
closedir ( $list ) ; /关闭 目录 
} 
} 
> 
脚下 留神 : 


bool is_dir0 男 数 结果 会 被 含 绝 ， 该 函数 不 能 作用 于 远程 文件 ， 被 检查 的 文件 必须 通过 | 
服务 器 的 文件 系统 访问 。 


技术 要 点 
本 实例 实现 的 关键 是 目录 和 文件 处 理 函数 的 应 用 , 包括 file_exists()、is_dir0、opendir()、 | 
readdir() 和 closedir0 函 数 。 | 
(1) file_exists(): 检查 文件 或 目录 是 否 存 在 。 语 法 如 下 : 
bool file_exists(string filename) 
如 果 由 filename 指定 的 文件 或 目录 存在 则 返回 ttue， 否 则 返回 false。 
(2) is_dir0: 判断 给 定 的 文件 名 是 否 是 一 个 目录 。 
bool is_dir(string filename) | 
如 果 文 件 名 存在 并 且 为 目录 则 返回 tue。 如 果 filename 是 一 个 相对 路 径 ， 则 按照 当前 | 
工作 目录 检查 其 相对 路 径 。 | 
(3) opendir(): 打开 目录 句柄 。 语 法 如 下 : 
resource opendir ( string path) | 
本 函数 返回 一 个 目录 句柄 ， 可 以 在 closedir0，readdir0 之 前 调用 。 如 果 path 不 是 一 个 | 
合法 的 目录 或 者 因为 权限 限制 或 文件 系统 错误 而 不 能 打开 目录 ,opendir0 返 回 false 并 产生 | 
一 个 错误 信息 。 
(4) readdir0: 从 目录 句柄 中 读 取 条 目 。 语 法 如 下 : 
string readdir( resource dir_ handle) 
本 函数 返回 目录 中 下 一 个 文件 的 文件 名 。 文 件 名 以 在 文件 系统 中 的 排序 返回 。 
(5) closedir0: 关闭 目录 句柄 。 语 法 如 下 : 
string closedir( resource dir_ handle) 
本 函数 关闭 由 dir handle 指定 的 目录 流 ， 目 录 流 必须 被 opendir0 打 开 过 。 


多 学 两 招 : 
本 实例 中 只 是 可 以 浏览 到 指定 目录 下 包含 的 文件 ， 不 可 以 对 文件 进行 操作 。 
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实例 198 ”可 以 屏蔽 刷新 功能 的 文本 计数 器 


( 实例 位 置 配套 资源 \SL\11\198 视频 位 置 : 配套 资源 \SP\11\198 ) 


实例 说 明 
网 站 的 计数 器 对 于 网 站 管理 者 来 说 是 一 个 非常 值得 关注 的 部 分 ， 它 记录 了 网 站 被 访问 


| 的 次 数 ， 客 观 地 反映 了 网 站 受 欢迎 的 程度 。 


而 文本 计数 器 是 最 简单 的 一 种 ， 采 用 将 数据 存储 于 文本 文件 中 。 在 本 实例 中 ， 将 介绍 


| 这 种 文本 计数 器 的 实现 方法 ， 并 且 将 重点 曾 述 如 何 屏蔽 网 页 刷新 对 计数 器 的 影响 。 运 行 本 
| 实例 ， 将 输出 如 图 11.7 所 示 界面 。 


| 实现 过 程 


最 新 动态 。 。 此 时 是 :2010 年 7 月 6 日 16:33:51 ”你 是 本 网 站 第 1800008 位 访客 * 


图 11.7 可 以 屏蔽 刷新 功能 的 文本 计数 器 


具体 步骤 如 下 : 
(1) 创建 index.php 文件 。 首 先 ， 设 计 网 页 页 面 。 然 后 ， 初 始 化 SESSION 变量 。 接 
着 ,编写 PHP 脚本 ， 通 过 文件 系统 函数 完成 网 站 访问 量 的 统计 ， 通 过 SESSION 屏蔽 网 页 
刷新 对 计数 器 的 影响 。 最 后 ， 输 出 网 站 的 访问 量 和 当前 时 间 。 其 关键 代码 如 下 : 
<2php 
session start (); // 初 始 化 一 个 SESSION 变量 
?> 


<2php 
/使 用 文本 存储 数据 
这 ($_SESSION [temp] 一 ") { V// 刊 断 $S_ SESSION[temp] 一 "的 值 是 否 为 室 ， 其 中 的 temp 为 自 
定义 的 变量 
if (($fp = fopen ( "counter.txt", "1" )) 一 false) { 


echo "打开 文件 失败 1"; 
}else { 
$counter = fgets ( $ 印 , 1024 ); 。“”// 读 取 文 件 中 数据 
felose ( $fp ); // 关 闭 文 本 文件 
$counter ++: /计数 器 增加 1 
$ 印 =fopen ( "counter.txt", "w" ); // 以 写 的 方式 打开 文本 文件 <!----> 
fputs ( $fp, $counter ): /将 新 的 统计 数据 增加 1 
felose ( $fp ); // 关 闭 文件 
} 
$_SESSION [temp] = 1; /计数 器 的 值 增加 后 .为 $ SESSION[temp] 赋 值 1 
上 
/从 文本 文件 中 读 取 统计 数据 
if(($fp= fopen ( "counter.txt", "r" )) =— false) { 
echo "打开 文件 失败 1"; 
}else{ 


$counter = fgets ( $fp, 1024 ); // 读 取 文 本 文件 的 数据 
。308 。 
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felose ( $fp ); 


上 
?> 


(2) 在 实例 根 目 录 下 创建 countertxt 文本 文件 ， 用 于 存储 网 站 的 访问 量 。 


技术 要 点 


文本 计数 器 的 设计 思路 如 下 : | 
首先 ， 判断 文本 文件 是 否 存 在 ， 如 不 存在 则 打开 失败 ;如 打开 成 功 则 继续 执行 读 取 | 


文件 中 的 数据 ， 将 计数 器 增加 1; | 
其 次 ， 新 用 户 访问 网 页 时 ， 处 理 页 以 写 入 的 方式 重新 打开 文件 ， 把 新 的 统计 数据 写 入 | 


到 文件 中 ， 关 闭 文件 ; 
最 后 ， 重 新 打开 文件 ， 读 取 并 输出 文件 中 的 数据 。 


其 操作 流程 如 图 11.8 所 示 。 


图 11.8 文本 计数 器 的 操作 流程 | 
按照 这 个 原理 设计 的 计数 器 ， 当 页 面 刷新 时 计数 器 的 值 就 会 增加 ， 那 么 这 个 计数 器 就 | 

没有 任何 意义 。 所 以 要 想 这 个 计数 器 有 意义 ， 必 须 屏蔽 页 面 刷 新 对 计数 器 的 影响 。 | 
这 里 通过 SESSION 来 实现 这 个 功能 ， 其 原理 如 图 11.9 所 示 。 


直接 输出 网 站 访问 量 
上 
mm 附录 本 于 村 | 交 量 是 天 为 空 

网 站 录 标 记 


SESSION 变 
量 赋值 为 1 


重新 输出 网 将 数据 添加 
站 访问 量 文本 文件 中 


图 11.9 网 站 计数 器 的 设计 原理 


多 学 两 招 : | 

首先 ， 在 网 页 被 访问 时 ， 初 始 化 一 个 SESSION 变量 ， 并 赋 给 其 一 个 空 值 。 然 后 ， 判 ， 

断 SESSION 变量 的 值 是 否 为 室 ， 如 果 为 空 ， 则 将 计数 器 的 值 增加 1， 并 且 为 SESSION 变 | 

量 赋值 为 1。 此 时 ,在 当前 页 中 ,SESSION 变量 的 值 已 经 不 为 空 , 无 论 如 何 刷新 , SESSION | 

变量 的 值 都 不 会 改变 ， 所 以 计数 器 的 值 也 不 会 增加 。 | 
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实例 199 ”从 文本 文件 读 取 注册 服务 条 款 


( 实例 位 置 配套 资源 \SL\11\199 视频 位 置 配套 资源 \SP\11\199 ) 


Eanl 实例 说 明 


| 在 网 站 开发 的 过 程 中 ， 经 常会 创建 注册 服务 条 款 或 者 会 员 须 知之 类 的 文件 。 处 理 此 类 
| 文件 的 最 直接 方法 是 将 它 生成 一 个 独立 的 页 面 ， 而 最 实用 的 方法 是 将 它 存储 于 独立 的 文本 
| 文件 中 ， 从 文本 文件 中 读 取 这 些 服务 条 款 ， 它 不 占用 数据 库 的 空间 ， 而 且 不 占用 过 多 的 页 
| 面 。 运行 本 实例 ， 实 现 一 个 用 户 注 册 的 功能 ， 并 从 文本 文件 中 读 取 服务 条 款 ， 运 行 结果 如 
| 图 11.10 所 示 。 


EE © E25R RSE BEE 
攻 录 名 : 


确认 密码 : 
rr 
了 -msil ty 四 
Pemananogmacom th 
联系 电话 : 迎 你 注册 为 明日 编 程 词典 服务 网 用 户 ; 到 
用 户 在 使 用 编程 词典 服务 网 网 络 服务 过 程 中 ， 
本 [or 不 得 利用 本 避 | 


( 念 我 已 网 读 条 款 ， 确 认 注册 ) 
他 ) 1999-2003 吉 林 省 明日 科技 有 限 公司 


图 11.10 从 文本 文件 中 读 取 注 册 服 务 条 款 


现 过 程 


具体 步骤 如 下 : 
(1) 创建 index.php 文件 。 
首先 ， 设 计 用 户 注册 页 面 。 
其 次 ， 添 加 用 户 注 册 的 表单 及 表单 元 素 ， 将 表单 元 素 的 值 提交 到 index_ok.php 页 。 
再 次 ， 编 辑 JavaScript 脚本 ， 通 过 chkreginfo0 方 法 对 表单 元 素 的 值 进行 判断 。 
| 最 后 ， 在 文本 域 中 编写 PHP 脚本 ， 通 过 file0 函 数 读 取 指定 文本 文件 中 的 数据 ， 通 过 
| foreach 语句 循环 输出 注册 服务 条 款 。 其 关键 代码 如 下 : 
| <textarea name="register" cols="40" rows="5" id="register"> 
<2php 
S$arr = file ( 'files/register.txt’ ): // 读 取 register.txt 文本 文件 中 的 内 容 
foreach ( $arr as $value ) { // 循 环 输出 文本 文件 中 的 内 容 
echo iconv ( "gb2312", "utf-8", $value ): 
} 


?> 
</textarea> 
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(2) 创建 index_ok php 文件 ， 通 过 $ POST 方法 获取 表单 中 提交 的 数据 ， 输 出 用 户 | 
的 注册 信息 。 
(3) 在 根 目录 下 创建 js 脚本 文件 夹 ， 编 写 checkjs 脚本 文件 ， 完 成 对 表单 元 素 值 的 | 


技术 要 点 
从 文本 文件 中 读 取 注 册 服 务 器 条 款 ， 可 以 分 为 两 个 部 分 : 第 一 部 分 是 表单 中 文件 域 的 | 
创建 ， 第 二 部 分 是 应 用 文件 系统 函数 读 取 、 输 出 指定 文本 文件 中 的 数据 。 | 
这 里 应 用 文件 系统 中 的 file0 函 数 读 取 文 本 文件 中 的 数据 。 | 
file0 函 数 将 整个 文件 的 内 容 读 入 到 一 个 数组 中 。 成 功 返 回 数组 ， 数 组 中 的 每 个 元 素 都 | 
是 文件 中 对 应 的 一 行 ， 包 括 换行 符 在 内 ;失败 返回 false。 语 法 如 下 : | 
array file ( string filename [, int use_include_path [, resource context]] ) 
其 参数 与 readfile0 函 数 相 同 ， 唯 一 区 别 是 该 函数 返回 值 是 数组 。 


多 学 两 招 : | 
在 文件 系统 函数 中 ， 有 多 个 可 以 读 取 文 本 文件 中 数据 的 函数 ， 为 了 让 读 取 到 的 数据 输 | 
出 时 条 理 更 加 清晰 ， 建 议 使 用 fleO 函 数 ， 因 为 该 函数 将 读 取 到 的 数据 写 入 一 个 数组 中 数 | 
组 中 的 每 个 元 素 是 文件 中 对 应 的 一 行 ， 这 样 在 通过 foreah 语句 输 出 数组 中 元 素 时， 就 是 按 | 
照 原来 文件 中 的 行进 行 输出 ， 确 保 了 内 容 输 出 的 条 理性 。 | 


实例 200 遍历 、 删 除 指定 文件 目录 下 的 所 有 文件 


( 实例 位 置 : 配套 资源 \SL\11\200 ) 


实例 说 明 | 

通过 对 网 站 目录 的 遍历 ， 能 够 更 快 地 了 解 网 站 的 结构 、 网 站 文件 的 存储 位 置 ， 通 过 对 | 
文件 内 容 的 遍历 ， 掌 握 网 站 中 每 个 文件 的 作用 、 同 时 也 便于 对 目录 和 文件 的 管理 。 本 实例 | 
中 将 介绍 如 何 实现 目录 和 文件 的 遍历 以 及 删除 。 运 行 本 实例 ， 如 图 11.11 所 示 。 


中 
四 让 有 日 ;xXx 件 管 理 系 t 
ol 

创建 日 其 量 后 修改 时 间 操作 
2010-08-09 02.42:12 2010-06-09 cc:42:14 出 除 
-0E-04 06 26-09 2010-06-04 06:23:10 者 队 
2010-0e-09 02 42:18 。。 2010-26-09 2: 起 :18 。。 黄 除 
03.07:01 。。 2010-06-09 03:07:02 删除 
2010-0e-09 07 19:01 。。 2010-36-09 07:21:22 。。 抽 除 
:23:23 2010-96-09 2 出 队 
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图 11.11 遍历 、 操 作 指 定 目录 下 的 所 有 文件 
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| 实现 过 程 


具体 步骤 如 下 
会 内 | (1) 创建 index.php 文件 。 应 用 目录 、 文 件 处 理 函数 和 字符 串 处 理 函 数 完 成 对 指定 目 
全 一 录 下 文件 的 读 取 操作 ， 并 设置 查看 文件 内 容 的 超 链接 和 删除 指定 文件 的 超 链 接 。 在 设置 超 
| 链接 的 参数 时 , 应 用 urlencode0 函 数 对 字符 串 进 行 编码 , 其 完整 代码 请 参考 本 书 配套 资源 。 
(2) 创建 look_file.php 文件 ， 完 成 对 指定 文件 内 容 的 读 取 操 作 。 其 关键 代码 如 下 : 
<2?php 
$catalog = iconv ( "utf-8", "gb2312", urldecode ($_GET [catalog] ) ); /获取 文件 的 信息 ， 设 置 编码 
$filename = iconv ("utf-8", "gb2312", urldecode ($_GET [filename] ) ); /获取 文件 的 信息 ， 设 置 编码 
$type = iconv ( "utf-8", "gb2312", urldecode ( $_GET [type] )); // 获 取 文 件 的 信息 ， 设 置 编码 


$types = strtoupper ( $type ); // 完 成 字符 串 的 大 小 写 转 换 
if ($types 一 "PHP") { // 显 示 PHP 文件 的 内 容 
$arr = file ( $catalog . "\" . $filename ): /1/ 读 取 文 件 
foreach ( $arr as $value ) { /循环 输出 文件 内 容 
$value = htmlentities ( $value, ENT_ COMPAT, "UTF-8" ); /特殊 字符 的 转换 
echo $value . "<br>"; // 输 出 内 容 
} 
} else { 
$fp = fopen ($catalog . "\\" . $filename, "1" ); // 显 示 txt 文件 的 内 容 


while ( $line = feets ( $fp ) ) { 
Sline = htmlentities ( $line, ENT_COMPAT, "GB2312" ); /特殊 字符 的 转换 
echo iconv ( "gb2312", "utf-8", $line ): /输出 文件 内 容 


} 
felose ( $fp ); 


} 


> 
| (3) 创建 delete.php 文件 ， 用 户 单 击 首页 文件 对 应 的 “删除 ” 超 链接 ， 完 成 对 指定 文 
| 件 的 删除 操作 。 
遍历 、 操 作 指 定 目录 下 的 所 有 文件 关键 是 目录 、 文 件 处 理 函 数 和 字符 串 处 理 函 数 的 综 
| 合 运用 。 
关键 的 目录 处 理 函 数 如 下 : 
(1) chdir0 函 数 ， 改 变 当前 目录 。 语 法 如 下 : 


bool chdir(string directory) 


参数 directory 用 于 指定 更 改 后 目录 的 位 置 。 操 作成 功 返 回 tre， 否 则 返回 false。 
(2) getcwd0 函 数 ， 获 取 当 前 工作 的 目录 。 语 法 如 下 : 


string getcwd( void): 
(3) rmdir0 函 数 ， 删 除 目录 。 语 法 如 下 : 
bool rmdir ( string dimame ) 
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尝试 删除 参数 dimname 所 指定 的 目录 。 该 目录 必须 是 空 的 ， 而 且 要 有 相应 的 权限 。 如 | 
果 成 功 则 返回 tue， 失 败 则 返回 false。 | 
在 对 文件 进行 操作 时 ， 主 要 应 用 到 如 下 几 个 函数 : | 
(1) fopen0) 函 数 、fgets0 函 数 、 pon ng fclose0) 函 数 ， 有 关 这 4 个 函数 已 经 在 | 
前 面 实例 文件 操作 汇总 中 介绍 过 ， 这 里 不 再 袭 | E 
(2) filectimeO 函 数 ， 返 回 指定 文件 的 索引 和 点 修改 时 间 。 语法 如 下 : 
int filectime(string filename); 
返回 文件 上 次 索引 节点 被 修改 的 时 间 ， 如 果 出 错 则 返回 false。 时 间 以 UNIX 时 间 蕉 的 | 
方式 返回 。 | 
(3) filemtime0 函 数 ， 返 回 指定 文件 flename 的 最 后 修改 时 间 。 语 法 如 下 : 


int filemtime(string filename); 


返回 文件 上 次 被 修改 的 时 间 ， 失 败 则 返回 false。 时 间 以 UNIX 时 间 戳 的 方式 返回 。 
(4) unlinkO 函 数 ， 删 除 文件 。 语 法 如 下 : 
bool unlink ( string filename ) 


删除 由 字符 串 flename 指定 的 文件 。 成 功 则 返回 tue， 失 败 则 返回 false。 

在 完成 对 目录 和 文件 的 遍历 以 及 删除 过 程 中 ， 应 用 到 下 面 的 字符 串 函数 : 

substr0 函 数 ， 从 指定 的 字符 串 中 按照 指定 的 位 置 截取 一 定 长 度 的 字符 。 语 法 如 下 ; 
string substr(string str,int start,int length) 


参数 说 明 : 

回 str: 指定 字符 串 对 象 。 | 

回 start: 指定 开始 截取 字符 串 的 位 置 。 如 果 参 数 start 为 负数 ， 则 从 字符 串 的 末尾 开 | 

回 length: 可 选 参数 ， 指 定 截 取 字 符 的 个 数 ， 如 果 length 为 负数 ， 则 表示 取 到 倒数 | 
第 length 个 字符 。 | 


指点 迷津: 
substr0 卫 数 中 参数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 于 中 的 第 一 个 字符 表示 0。 | 


多 学 两 招 : 

在 通过 URL 传递 字符 事 参 数 时 ， 尽 量 应 用 urlencode() 函 数 对 传递 的 参数 值 进行 编码 ， | 
这 样 不 但 可 以 保证 传递 参数 值 的 安全 ， 而 且 可 以 防止 传递 的 参数 值 出 现 乱码 的 问题 例 | 
如 ， 本 实例 中 在 执行 指定 目录 、 文 件 的 删除 操作 时 ， 在 执行 成 功 跳 转 到 上 级 页 面 时 ， 如 | 
果 不 对 URL 传递 的 字符 囊 参 数值 进行 编码 ， 那 么 就 不 能 够 完成 跳 转 的 操作 ， 会 弹出 一 个 | 
错误 提示 。 | 
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实例 201 文件 属性 分 析 


( 实例 位 置 : 配套 资源 \SL\11\201) 


如 果 说 判断 目录 、 文 件 是 否 存在 是 对 目录 、 


| 文件 进行 操作 的 前 提 条 件 ， 那 么 获取 文件 属性 则 ee 

”是 对 文件 进行 操作 的 必要 条 件 。 因 为 在 执行 一 些 Bn 

| 特殊 的 操作 之 前 ， 必 须 对 文件 的 类 型 、 大 小 或 者 3 

| 修改 时 间 进 行 判断 。 在 本 实例 中 ， 将 介绍 如 何 获 一 

! m Wei 文件 名 称 : FwppSewwwWMRO4D15Wndexphp 

| 到 文 件 的 类 型 、 大 小 和 修改 时 间 。 运 行 本 实例 ， ee 

| 在 文本 框 中 输入 一 个 正确 目录 或 者 文件 的 路 径 ， a 

| 单 击 “提交 ”按钮 ， 运 行 结果 如 图 11.12 所 示 。 二 Eee an 

| 实现 过 程 图 11.12 文件 属性 分 析 
具体 步骤 如 下 : 


(1) 创建 index.php 文件 ， 设 计 页 面 布局 。 
| (2) 添加 表单 ， 设 置 目录 、 文 件 提交 的 文本 框 ， 提 交 目 录 或 者 文件 的 路 径 ， 并 设置 
| 提交 按钮 。 

| (3) 创建 PHP 脚本 ， 获 取 表 单 中 提交 的 元 素 值 。 首 先 ， 判 断 提 交 的 值 是 否 为 空 ， 如 
| 果 不 为 空 ， 则 应 用 iconv0 函 数 对 字符 串 的 编码 格式 进行 转换 。 然 后 ， 应 用 file_exists0 函 数 
| 判断 指定 的 目录 或 者 文件 是 否 存在 ， 如 果 存 在 则 获取 目录 或 者 文件 的 类 型 、 大 小 以 及 修改 
| 时 间 。 其 关键 代码 如 下 : 


<?php 
if (isset($_ POST ['file name])) { 1/ 判断 表单 提交 的 值 是 否 为 空 
$file name =iconv ("utf-8", "gb2312", $_POST [file name'] ); /完成 编码 格式 的 转换 
if (file_exists ( $file name )) { 1/ 判断 目录 或 者 文件 是 否 存在 
$file_ type = filetype ( $file_ name ): // 获 取 文 件 类 型 
echo "<br> 文 件 类 型 : ". $file type . "<br>"; 
让 ($file type!= "dir") { /判断 如 果 不 是 目录 
$file_size = filesize ( $file name ); 1/ 获取 文件 的 大 小 
echo "文件 大 小 : " . $file size ." 字 节 " . "<br>"; 
} 
$file mtime = filemtime ( $file name ); 1/ 获取 目录 或 者 文件 的 修改 时 间 
echo "修改 时 间 : " . date ("Y-m-d H:i:s", $file_ mtime ); /对 返回 的 时 间 惟 进行 格式 化 输出 
}else{ 
echo "<script>alert( 目 录 、 文 件 不 存在 ! "):</script>"; 
}else{ 
echo "<script>alert( 请 输入 正确 的 目录 、 文 件 路 径 ! ");</script>"; 
} 
?> 
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技术 要 点 | 
PHP 中 获取 文件 类 型 是 fletype0 函 数 ， 获 取 文件 大 小 是 filesize0 函 数 ， 而 获取 修改 时 | 
间 是 femtime(0) 函 数 。 | 
filetype0 函 数 ， 获 取 文 件 类 型 。 其 语法 如 下 : 
string filetype ( string filename ) 
该 函数 返回 文件 的 类 型 。 类 型 值 包括 : fifo、char、dir、block、link、file 和 unknown。| 
如 果 出 错 则 返回 false。 如 果 stat 调用 失败 或 者 文件 类 型 未 知 的 话 f 甸 etype0O 还 会 产生 一 | 
个 E NOTICE 级 别 的 错误 消息 。 | 
filesize() 函 数 ， 获 取 文 件 大 小 。 
int filesize ( string filename ) 


该 函数 返回 文件 大 小 的 字 节 数 ， 如 果 出 错 返回 false 在 错误 报告 级 别 为 E_ WARNING 的 
情况 下 )。 | 


指点 迷津 : | 
因为 PHP 的 整数 类 型 是 有 符号 的 ， 并 且 大 多 数 平台 使 用 32 位 整数 ，filesize0) 函 数 在 | 
碰 到 大 于 2GB 的 文件 时 可 能 会 返回 非 预 期 的 结果 .对 于 2~ 4GB 之 间 的 文件 通常 可 以 使 用 | 
sprintfl"%ou", filesize($file)) 来 克服 此 问题 。 | 
多 学 两 招 ; | 

在 PHP 内 置 的 文件 系统 操作 函数 中 ， 不 仅 可 以 获取 到 文件 的 类 型 、 大 小 和 修改 时 间 ， | 
而 且 可 以 获取 到 文件 的 上 次 访问 时 间 (fileatime() )、inode 修改 时 间 (filectime() )、 文 件 的 | 
组 (filegroup())、 文 件 的 所 有 者 ( fileowner() ) 和 文件 的 权限 ( fileperms() ) 等 。 | 


实例 202 将 文本 文件 中 的 内 容 存储 到 数据 库 中 


( 实例 位 置 : 配套 资源 \SL\11\202 ) 


实例 说 明 
文本 文件 中 的 数据 也 可 以 转 存 到 数据 库 中 。 


例如 ， 在 编程 词典 服务 网 中 ， 有 一 个 编程 | 
词典 系列 软件 注册 信息 提交 页 面 , 在 该 页 面 


EE EF SE [国有 国 


中 编程 词典 用 户 不 但 提交 个 人 信息 , 而 且 将 | HA 
安装 编程 词典 生成 的 注册 信息 文件 提交 到 ee 了 
服务 器 中 , 在 提交 注册 信息 的 同时 , 将 注册 Henan i 
信息 中 的 数据 与 用 户 个 人 信息 一 起 存储 到 


数据 库 中 。 本 实例 模拟 这 个 功能 ， 开发 一 个 
将 文本 文件 上 传 到 服务 器 , 并且 将 文本 文件 
中 数据 转 存 到 数据 库 中 的 实例 。 其 运行 结果 
如 图 11.13 所 示 。 
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图 11.13 将 文本 文件 中 的 内 容 存储 到 数据 库 中 
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| 实现 过 程 
| 具体 步骤 如 下 ; 


(1) 创建 index.php 文件 。 首 先 ， 设 计 网 页 页 面 。 然 后 ， 创 建 一 个 表单 ， 通 过 文件 域 


提交 要 上 传 的 ini 文件 。 接 着 ， 获 取 表 单 中 提交 的 文件 ， 将 文件 存储 到 服务 器 指定 的 文件 


夹 下 ， 通 过 file_get_contents0 函 数 读 取 上 传 文件 的 内 容 ， 并 且 将 读 取 的 结果 存储 到 指定 
| 的 数据 表 中 。 最 后 ， 执 行 查询 语句 ， 输 出 数据 库 中 存储 的 ini 文件 的 内 容 。 其 关键 代码 
如 下 : 
<2php 
if(! empty ($_ FILES [up_picture'] ['name’] )) { // 判 断 上 传 内 容 是 否 为 空 
$type = $_FILES [up_picture] [name']; 
$types = strstr ( $type, ".' ); // 获 取 文 件 后 级 
if ($types =— "ini") { 
if ($_FILES [up picture'] [error] > 0) { // 判 断 文件 是 否 可 以 上 传 到 服务 器 
echo "上 传 错 误 :"; 
Switch ($_FILES [up_picture] [error]) { 
case 1: 
echo "上 传 文件 大 小 超出 配置 文件 规定 值 "; 
break; 
case2 : 
echo "上 传 文件 大 小 超出 表单 中 约定 值 "; 
break; 
case3 : 
echo "上 传 文件 不 全 "; 
break; 
case 4: 
echo "没有 上 传 文件 "; 
break; 
} 
}else { 
if (lis_dir ("./upfile/" )) { // 判 断 指定 目录 是 否 存在 
mkdir( "./upfile/" ); // 创 建 目 录 
} 
$file name = time 0 . strstr ( $_FILES [up_picture] [name'],'…):/ 定 义 上 传 文件 名 称 
$path =' /upfile/ . $file name: // 定 义 上 传 文件 名 称 和 存储 位 置 
寺 (is_uploaded_file ($_FILES [up_picture'] [tmp_name'] )) { // 判 断 文 件 是 否 是 HTPP 
POST 上 传 
if (! move_uploaded file ( $_ FILES [up_picture'] [tmp_name'], $path )) { // 执 行 
上 传 操 作 
echo "上 传 失 败 "; 
}else{ 


// 读 取 文本 文件 中 数据 ， 并 且 实 现 转 义 和 编 码 的 转换 

Sarr = iconv ( "gb2312", "utf-8", addslashes ( file_get_contents ( $path ) ) ); 
include_once ("conn/conn .php"); 1/ 连接 数据 库 

$sql = "insert into tb files(file name,file content,file date)values($file 
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name,','$arr'," . date ("Ym-d His" ) . ")"; /定义 SQL 添加 语句 
Sresult = mysql query ( $sql, $conn ): /执行 添加 操作 


echo "文件 “" .$_FILES [up _picture] [name] . ”上传 成 功 !". "<br>"; 
echo "大 小 : ".$ FILES [up _ picture] [size] . ” 字 节 "; 


} 
}else{ 
echo "上 传 文件 " . $_FILES [up _pictute] [name'] . "不 合法 ! "; 
} 
} 
}else{ 
echo "上 传 文件 " . $_FILES [up _pictute'] [name'] . "类 型 不 正确 ! "; 
} 
} 
?> 


(2) 创建 conn 文件 夹 ， 编 写 conn php 文件 ， 连 接 数 据 库 服务 器 ， 连接 db_databasell | 
数据 库 。 其 代码 如 下 : 


<?php | 
$conn = mysql_connect ("localhost", "root", "111" ) or die ( "连接 数据 库 服务 器 失败 ! " . mysql 


error 0 ); 
mysql select db ("db _databasell", $conn ); // 选 择 数 据 库 db_databasel1 
mysql_query ( "set names utf8" ); // 设 置 数据 库 编码 格式 UTF-8 
?> 
技术 要 点 | 
在 本 实例 中 ， 运 用 了 三 个 方面 的 技术 : 第 一 将 文本 文件 上 传 到 服务 器 第 二 读 取 服务 | 


器 指定 文件 夹 下 的 文本 文件 中 的 数据 :第 三 连接 数据 库 ， 将 从 文本 文件 中 读 取 的 数据 存储 | 
到 指定 数据 表 中 。 | 
其 中 ， 最 为 关键 的 是 将 文本 文件 中 的 数据 存储 到 数据 库 中 ， 在 执行 数据 的 读 取 和 存储 | 
时 ， 有 两 个 细节 必须 把 握 。 第 一 个 ， 应 用 addslashes0 函 数 ， 对 从 文本 文件 中 读 取 的 数据 进 | 
行 转 义 , 因为 在 读 取 的 数据 中 可 能 包含 单 引号 ()、 双 引号 (")、 反 斜 线 (\) 或 者 NUL(NULL | 
字符 )， 如 果 不 对 其 进行 转换 ， 在 执行 SQL 语句 时 可 能 会 出 现 错误 。 | 
addslashes() 函 数 ， 通 过 反 斜 线 来 引用 字符 串 。 语 法 如 下 : 
string addslashes ( string str) | 
在 其 返回 的 字符 串 中 ， 为 了 数据 库 查 询 语句 等 的 需要 在 某 些 特定 字符 前 加 上 了 反 斜 | 
线 。 这 些 特定 字符 包括 : 单 引号 (D)、 双 引号 (")、 反 斜 线 (\) 和 NUL (NULL 字符 )。 | 


指点 迷津 : | 

默认 情况 下 ,PHP 指令 会 自动 对 所 有 的 GET.POST 和 COOKIE 数据 运行 addslashes() | 
函数 。 所 以 ， 如 果 是 通过 GET 或 者 POST 方法 提交 的 数据 是 不 需要 进行 转 义 的 ， 可 以 直 | 
接 添加 到 数据 库 中 ; 如 果 提交 的 数据 是 从 文本 文件 中 读 取 或 者 自 定义 的 内 容 ， 那 么 就 有 必 
要 对 其 进行 转 义 。 | 
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| 多 学 两 招 : 
| 将 从 文本 文件 中 读 取 的 数据 存储 到 数据 库 时 ,必须 应 用 addslashes() 函 数 对 文本 文件 返 
” 回 的 字符 囊 进行 转 义 ， 否 则 将 会 出 现 错误 。 


食 
实例 203 ”判断 文件 是 否 被 改动 
| ( 实例 位 置 : 配套 资源 \SL\11\203 ) 
| 实例 说 明 
| “在 网 站 的 管理 系统 中 ， 有 时 需要 查看 某 
| 个 文件 是 否 被 修改 过 ， 在 什么 时 间 被 修改 es 
| 的 ， 最 后 的 改变 时 间 是 什么 时 候 。 本 实例 就 i 


| 可 以 实现 这 个 功能 ， 对 表单 中 提交 的 文件 进 
| 行 判断 ， 检 测 出 它 的 修改 时 间 ， 其 运行 结果 
| 如 图 11.14 所 示 。 

现 过 程 图 11.14 判断 文件 是 否 被 改动 


| 首先 ， 创 建 PHP 文件 ， 并 应 用 图 片 布局 设置 网 页 页 面 。 然 后 ， 在 创建 的 PHP 文件 内 
| 创建 一 个 表单 ， 通 过 文件 域 提交 要 判断 的 文件 。 接 着 ， 获 取 表 单 中 提交 的 文件 路 径 ， 应 用 
| filectime0 和 filemtime0) 函 数 对 提交 的 文件 进行 检测 。 最 后 ， 当 用 户 单 击 “ 浏 览 ” 按 钮 选取 
| 本 地 文件 后 ， 继 续 单 击 “ 提 交 ” 按 钮 即 可 输出 检测 结果 。 

index.php 文件 的 关键 代码 如 下 : 


<2?php 
ifisset($_POST['files])){ /判断 用 户 是 否 提交 文件 
$file = iconv ( "utf-8", "gb2312",$_ POST [files] ); /实现 编码 格式 的 转换 
让 (file exists ( $file )) { // 浏 断 文件 是 否 存在 
$change time = filectime ( $file ); // 获 取 文件 的 最 后 incode 时 间 
$time = date ( "Y-m-d h:i:s", $change time ): /时 间 戳 的 格式 化 
S$last_time = filemtime ( $file ): // 获 取 文 件 的 最 后 修改 时 间 
S$times = date ( "Y-m-d h:i:s", $last_time ): /时 间 惟 的 格式 化 
} else{ 
$result = "该 文件 不 存在 !1"; 
} 
| ?> 
| 技术 要 点 


| 本 实例 主要 应 用 名 ectime0 和 flemtime0 函 数 ， 检 测 文件 的 incode 最 后 改变 时 间 和 最 
| 后 的 修改 时 间 ， 并 应 用 date0) 函 数 对 检测 返回 的 时 间 戳 进行 格式 化 。 
filectime() 函 数 ， 返 回 指定 文件 filename 的 inode 最 后 改变 时 间 。 语 法 如 下 : 
| int filectime(string filename); 
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成 功 则 返回 UNIX 时 间 戳 ， 和 否则 返回 false。 

filemtimeO 函 数 ， 返 回 指定 文件 和 iename 的 最 后 修改 时 间 。 语 法 如 下 : 
int filemtime(string filename); 

成 功 则 返回 UNIX 时 间 戳 ， 和 否则 返回 false。 


多 学 两 招 : 
通过 文件 系统 函数 不 但 可 以 获取 到 文件 的 最 后 修改 时 间 ， 而 且 可 以 获取 到 文件 的 最 后 
访问 时 间 ， 其 应 用 的 是 fleatimeO 函 数 。 | 


实例 204 目录 操作 汇总 


( 实例 位 置 配套 资源 \SL\11\204 视频 位 置 : 配套 资源 \SP\11\204 ) 


实例 说 明 | 

在 前 面 的 实例 中 ， 已 经 涉及 到 很 多 目录 操作 的 方法 ， 例 如 ， 创 建 、 获 取 当 前 目录 、 删 
除 目录 等 。 在 本 实例 中 ， 将 对 目录 的 基本 操作 进行 一 次 汇总 ， 让 读者 对 目录 操作 方法 有 一 | 
个 系统 的 了 解 ,运行 本 实例 , 可 以 实现 目录 的 创建 、 浏 览 和 删除 操作 , 其 运行 结果 如 图 11.15 | 


管理 系统 -| 
Mngri Fles Management System 
x E 全 加 
人 J 
6 
| 四 I 
z- 
了 pos 
debtepkp 
Stebteda pip 
-1 
Bamtepip 
少 新 建文 件 夹 
I0:ook php 
[ LL:INDEX PHP 
1 CopyMithts a reseryed 2010 十 林 省 明日 科技 有 限 公司 
图 11.15 目录 操作 汇总 
实现 过 程 
具体 步骤 如 下 


(1) 创建 index.php 文件 。 通 过 switch 语句 编写 一 个 网 页 框架 ， 根 据 超 链接 中 传递 的 
参数 值 ， 在 index.php 页 面 中 完成 创建 目录 、 浏 览 目录 、 删 除 目 录 和 删除 文件 功能 之 间 的 | 
跳 转 。 其 关键 代码 如 下 : | 

<2?php 
switch ($_GET [dir]) { /获取 dir 路 径 
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Case "create" : 
include ("create.php"); 
break; 
| case "look" : 
天 六 | include ("look php"); 
2 break: 
case "deletedir" : 
include ("deletedir.php"); 
break; 
case "deletefile" : 
include ("deletefile.php"); 
break:; 
default : 
include ("look.php"); 
break; 


} 


?> 


/根据 获取 路 径 加 载 功 能 文件 


(2) 创建 create.php 文件 ， 应 用 mkdir0 函 数 完成 目录 的 创建 。 其 关键 代码 如 下 : 


< 
if (isset($_POST [Submit] )) { // 浏 断 用 户 是 否 执行 提交 操作 
S$file dir=iconv ( "utf-8", "gb2312", $ POST ['objfile'] ); // 将 文件 名 称 编码 格式 转换 
if (is_ dir ( $file dir )) { /判断 创建 的 目录 是 否 已 经 存在 
echo "<script>alert(' 目 录 已 经 存在 !):</script>"; // 提 示 用 户 目录 已 经 存在 
} else { 
if (mkdir ( $file dir )) { // 创 建文 件 目录 
echo "<script>alert( 目 录 创 建成 功 !);</script>"; // 提 示 用 户 目 录 创 建成 功 
}else { 
echo "<script>alert(' 目 录 创 建 失败 !");</script>"; ”// 提 示 用 户 目 录 创 建 失败 
} 
} 
} 
?> 


(3) 创建 look.php 文件 ， 通过 getewd0 函 数 定位 到 当前 日 录 ， 并 应 用 opendir0 函 数 和 
| readdir0 函 数 读 取 当 前 目录 中 的 内 容 ， 其 代码 请 参考 本 书 配套 资源 。 
| (4) 创建 deletedirphp 文件 ， 在 look.php 文件 的 基础 上 ， 为 输出 的 目录 创建 删除 超 链 
| 接 ， 链 接 到 delete.php 文件， 完成 目录 的 删除 操作 。 
| (5) 创建 deletefile.php 文件 ， 在 look.php 文件 的 基础 上 ， 为 输出 的 文件 创建 删除 超 
| 链接 ， 链 接 到 delete php 文件 ， 完 成 文件 的 删除 操作 。 
| (6) 创建 delete.php 文件 ， 分 别 应 用 rmdir0 函 数 和 unlink0 函 数 完成 目录 和 文件 的 删除 。 
| 技术 要 点 
| 本 实例 主要 应 用 mkdir0 函 数 、is_dir0 函 数 、getcewd0 函 数 、rmmdir0 函 数 、opendir0) 函 


| 数 和 readdir0 函 数 等 ， 完 成 目录 的 判断 、 创 建 、 打 开 、 读 取 和 删除 操作 。 所 使 用 函数 的 功 
| 能 和 语法 如 表 11.1 所 示 。 
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表 11.1 目录 操作 函数 汇总 


名 称 语 法 功 能 
本 新 建 一 个 由 pathname 指定 的 目录 。 参 数 mode 指定 目录 的 
mkdir0 | bool mkdirsting pathname | 模式 ,Mode 在 Windows 下 被 忽略 。 自 PHP 4.2.0 起 成 为 可 
人 选项 .默认 的 mode 是 0777， 意 味 着 最 大 可 能 的 访问 权 
ee op pb 如 果 文 件 名 存在 并 且 为 目录 则 返回 tue。 如 果 flename 是 
sd | boolis_ dir (sting 全 ename ) | 一 个 相对 路 径 ， 则 按照 当前 工作 月 录 检 查 其 相对 路 径 
getcwd0) string getcwd ( void) 返回 当前 的 工作 目录 
删除 dimame 所 指定 的 目录 。 该 目录 必须 是 空 的 , 而 且 要 有 
dr Peelemdir (sting dimame ) | 相应 的 权限 。 如 果 成 功 则 返回 true， 失 败 返回 false 
打开 一 个 目录 句柄 , 成 功 返 回 目录 句柄 的 resource， 失 败 返 
回 false。 返 回 值 可 用 于 closedir0 、readdir0 和 rewinddir0 
Tesource opendir ( string path | 函数 中 。 如 果 参 数 path 不 是 一 个 合法 的 目录 或 者 因为 权限 
pe [; resource context] ) 限制 或 文件 系统 错误 而 不 能 打开 目录 ，opendir0 返 回 false 
并 产生 一 个 E WARNING 级 别 的 PHP 错误 信息 。 可 以 在 
opendir0 前 面 加 上 “@” 符 号 来 抑制 错误 信息 的 输出 
ee 从 目录 句柄 中 读 取 条 目 ， 成 功 则 返回 目录 中 下 一 个 文件 的 
TIeaddir0 handle) 一 | 文件 名 ， 和 否则 返回 false。 其 参数 dir_ handle 是 目录 句柄 的 
resource， 之 前 由 opendir0 打 开 
多 学 两 招 : 


在 应 用 rmdirO 函 数 删除 指定 的 目录 时 ， 被 删除 的 路 径 必 须 是 空 的 目录 ， 并 且 权 限 必 须 
要 合乎 要 求 ， 否 则 将 返回 false。 
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本 章 读者 可 以 学 到 如 下 实例 : 


实例 205 使 用 类 的 属性 保存 数据 库 
连接 参数 

实例 206 ”数据 库 连 接 类 中 定义 数据 
库 连 接 方法 

实例 207 数据 统计 类 中 定义 求 数值 
实例 208 ”使 用 $this 关键 字 调 用 汽车 
类 自身 的 方法 

实例 209 学 生 类 中 使 用 构造 方法 为 
学 生 信息 初始 化 

实例 210 ”汽车 类 使 用 public 关键 字 
定义 汽车 的 行驶 方法 

实例 211 使 用 private 关键 字 定 义 汽 
车 的 颜色 属性 

实例 212 使 用 protected 关键 字 定 义 
汽车 的 保修 年 限 

实例 213 苹果 子 类 继承 水 果 父 类 
实例 214 使 用 parent 关键 字 调 用 父 
实例 215 苹果 字 类 中 覆盖 水 果 父 类 
中 的 方法 

实例 216 美食 抽象 类 

实例 217 学 生 类 多 重 接口 的 实现 
实例 218 ”通过 继承 实现 多 态 
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实例 219 通过 接口 实现 多 态 

实例 220 使 用 final 关键 字 防 止 类 
被 继承 

实例 221 使 用 static 关键 字 定 义 类 
的 静态 成 员 

实例 222 使 用 clone 关键 字 实 现 
对 象 的 克隆 

实例 223 使 用 _set() 方 法 为 类 中 
未 经 定义 的 属性 赋值 

实例 224 使 用 _get() 方 法 获取 未 
声明 属性 的 名 称 

实例 225 使 用 _call0 方 法 打印 类 
中 未 定义 方法 的 信息 

实例 226 使 用 _toString() 方 法 将 
类 的 实例 转化 为 字符 囊 

实例 227 使 用 _isset() 方 法 提示 
未 定义 属性 信息 

实例 228 使 用 单 例 模 式 制作 数据 
库 管 理 类 

实例 229 使 用 策略 模式 打印 客户 
端 浏 览 器 类 型 

实例 230 使 用 工厂 模式 设置 用 户 
访问 权限 
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实例 205 使 用 类 的 属性 保存 数据 库 和 连接 参数 


( 实例 位 置 : 配套 资源 \SL\12W205 视频 位 置 配套 资源 \SP\12\205 ) 


实例 说 明 


运行 本 实例 ， 如 图 12.1 所 示 。 首 先 在 图 中 的 文本 框 内 
输入 连接 MySQL 数据 库 服务 器 所 需 的 必 选 参数 ， 然 后 音 
击 “ 连 接 ” 按 钮 即 可 建立 与 指定 的 MySQL 数据 库 服务 器 
的 连接 ， 并 将 连接 结果 打印 在 页 面 中 。 
实现 过 程 
实现 本 实例 ， 首 先 需要 定义 数据 库 连 接 类 ， 然 后 建立 
数据 库 参 数 录入 表单 来 指定 数据 库 连 接 时 所 需要 的 连接 参 。 es 
数 ， 下 面具 体 讲解 该 数据 库 连接 类 的 设计 和 实现 过 程 。 | 
(1) 定义 数据 库 连接 类 ， 并 通过 类 的 届 性 保存 连接 MySQL 数据 库 所 需 的 参数 。 该 类 | 
的 具体 实现 代码 如 下 : 


class ConnDb 
{ 
private $host; /MySQL 数据 库 服 务 器 地 址 
private $username: 1/ 用 户 名 
private $password; // 密 码 
private $charset: /数据 库 编 码 
private $dbname; // 数 据 库 的 名 称 


public function __ construct ($host, $username, $password, $dbname, $charset = utf-8) /构造 | 
方式 实现 类 的 初始 化 | 
{ | 


Sthis->host = $host: // 初 始 服 务 器 地 址 | 
S$this->username = $usermmame: // 初 始 用 户 名 | 
S$this->password = $password; // 初 始 用 户 密码 | 
$this->dbname = $dbname; | 
S$this->charset = $charset: // 初 始 数 据 库 字 符 集 | 
) 
public function getConnId 0 /| 数据 库 连接 方法 | 
{ | 
@$connId = mysql_connect($this->host, $this->usemame, $this->password); // 获 得 数 | 
据 库 连接 句柄 | 
@mysql_select_db(S$this->dbname, $connId): | 
@mysql_query('set names ' . $this->charset); /设置 字符 集 | 
Tetum $connld; // 返 回 连接 句柄 | 

1 


FE 
上 述 代 码 中 , 定义 了 $host、$username、$password、$charset 和 $dbname 5 个 私有 属性 ， 
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可 
分 别 用 来 保存 数据 库 服务 器 的 主机 地 址 或 名 称 、 数 据 库 服务 器 用 户 名 、 用 户 密码 、 字 符 集 
和 要 连接 的 数据 库 名 , 并 通过 构造 方法 _constructO 实 现 数据 库 连 接 参 数 的 初始 化 , 最 后 定 
义 getConnId() 方 法 返回 数据 库 连 接 句柄 。 

(2) 建立 数据 库 连 接 参数 录入 表单 。 该 过 程 通过 HTML 语言 的 表单 标签 实现 ， 有 具体 
实现 代码 详 见 本 书 附 带 配套 资源 。 

(3) 当 单 击 数据 库 参 数 录入 表单 中 的 “连接 ”按钮 ， 将 会 使 用 如 下 代码 判断 是 否 成 


| 功 连 接 上 数据 库 。 


ifisset($_ POST[host])){ 
Tequire 'ConnDb.php'; // 包 含 数据 库 连 接 类 文件 
$connDb = new ConnDb($_ POST[host]， $ POST[usemame']， $ POST['password'], 


| S POSTTdbname].$ POSTTcharset]。 /实例 数据 库 连 接 类 


echo !$connDb->getConnId0? 数 据 库 连 接 失 败 ! "数据 库 连 接 成 功 ! ” /打印 连接 结果 
b 


上 述 代码 中 ， 首 先 通 过 isset($_POST[host]) 判 断 用 户 是 否 已 经 提交 了 表单 ， 如 果 是 则 


| 使 用 require0 语 句 包含 数据 库 连接 类 ， 然 后 使 用 new 关键 字 实例 该 类 ， 并 通过 调用 类 中 的 
| getConnId0 方 法 来 返回 数据 库 连 接 状 态 ， 最 后 打印 出 连接 结果 。 


| 多 学 两 招 ， 


用 “@ ”屏蔽 运行 期 错误 。 
在 程序 运行 时 ， 有 时 会 难以 避免 地 出 现 运行 时 错误 并 在 页 面 中 打印 错误 信息 ， 这 样 不 


| 仅 会 使 页 面 的 友好 性 大 打折 扣 ， 而 且 还 会 对 程序 的 安全 带 来 极 大 隐患 。 使 用 try/catch 语 白 
| 可 以 屏蔽 运行 期 错误 ， 不 过 需要 书写 的 代码 量 相对 较 大 。PHP 提供 了 “@” 关 键 字 来 屏蔽 
| 运行 期 错误 ， 只 要 在 可 能 发 生 运行 期 错误 代码 前 加 上 “(@” 即 可 ， 例 如 ， 本 实例 用 来 屏蔽 


| 连接 数据 库 失败 时 的 错误 提示 代码 如 下 
@$connId = mysql_connect($this->host, $this->username, $this->password); /获得 数据 库 连 接 句 柄 


技术 要 点 

类 是 对 事物 的 抽象 ， 在 对 类 进行 定义 时 合理 地 设置 类 的 属性 和 方法 较为 重要 。 例 如 ， 
在 本 实例 所 应 用 的 数据 库 连接 类 中 ， 将 数据 库 服务 器 地 址 、 数 据 库 服务 器 用 户 名 、 密 码 、 
数据 库 名 称 以 及 数据 库 字 符 集 作为 类 的 属性 保存 ， 而 将 数据 库 连 接 的 实现 过 程 定义 为 类 的 
方法 ， 这 是 因为 数据 库 连 接 参 数 在 类 的 生命 周期 内 基本 没有 变化 ， 而 且 属于 特性 范围 ， 所 
以 定义 为 类 的 属性 ， 而 数据 库 连 接 方法 属于 类 的 动作 或 功能 ， 所 以 定义 成 类 的 方法 。 

在 PHP5.0 以 前 版 本 中 ， 类 属性 使 用 关键 字 dim 声明 ， 通 过 该 关键 字 声 明 的 类 属性 可 
以 在 类 声明 周期 的 任何 范围 内 被 调用 。 而 在 PHP5.0 以 后 版 本 中 引入 了 public、protected 
和 private 关键 字 来 对 类 中 属性 或 方法 进行 声明 , 这 样 根据 不 同 的 关键 字 将 类 的 属性 或 方法 
划分 为 公有 成 员 、 保 护 成 员 和 私有 成 员 3 种 ， 其 中 不 同 关键 字 修 饰 的 类 成 员 的 说 明和 区 别 
如 下 : 

回 public: 表示 该 成 员 可 以 在 任何 范围 被 调用 ， 包 括 类 体内 部 、 该 类 的 子 类 和 类 实 
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例 的 对 象 。 
protected: 表示 该 方法 可 以 在 类 中 或 该 类 的 子 类 中 被 调用 。 
private: 表示 该 类 只 能 在 类 体内 被 调用 。 


指点 迷津: | 凶 | 


如 果 没有 对 类 中 方法 指定 任何 访问 权限 ， 则 PHP 会 默认 该 方法 的 访问 权限 为 public 
实例 206 数据 库 连 接 类 中 定义 数据 库 连 接 方法 


( 实例 位 置 : 配套 资源 \SL\12\206 视频 位 置 配套 资源 \SP\12\206 ) 


实例 说 明 


当 使 用 PHP 的 MySQL 函数 库 管 理 MySQL 数据 库 
时 ， 首 先 需 要 获得 数据 库 连接 句柄 ， 然 后 才能 进一步 进 
行 增 、 删 、 改 、 查 操作 。 运 行 本 实例 ， 首 先 在 图 12.2 所 
示 的 表单 中 输入 数据 库 连 接 参 数 ， 然 后 单 击 “连接 ” 按 
钮 ， 如 果 成 功 连接 上 MySQL 数据 库 则 会 在 页 面 中 打印 
出 数据 库 连 接 句 柄 。 


实现 过 程 
具体 步骤 如 下 : 
(1) 定义 数据 库 连接 类 ,在 类 中 定义 数据 库 连 接 的 图 12.2 打印 连接 句柄 
方法 getConnId0， 实 现 该 过 程 的 代码 如 下 : 
public function getConnId 0 /数据 库 连 接 方法 
{ | 
@S$connId = mysql_connect($this->host, $this->username, $this->password); // 获 得 数据 库 连 接 | 
句柄 | 
@mysql_select_db($this->dbname, $connId): 
@mysql_query('set names ' . $this->charset); /设置 字符 集 
return $connld; // 返 回 连接 句柄 


} | 

在 上 述 方法 中 ， 首 先 通 过 函数 mysqL_connect0 获 得 数据 库 连接 句柄 ， 然 后 使 用 函数 | 
mysql select_ db0 选 择 要 连接 的 数据 库 ， 并 使 用 函数 mysql query0 执 行 查询 语句 来 设置 数 | 
据 库 的 字符 集 。 | 
(2) 实例 数据 库 连 接 类 ， 并 打印 连接 句柄 ， 实 现代 码 如 下 所 示 ; | 
$connDb = new ConnDb($ POST[host]，$_ POST[usemame']，$ POST['password'], $_POST | 
[dbname'], $ POST[charset]); /实例 数据 库 连 接 类 | 
echo !$connDb->getConnId0?' 数 据 库 连接 失败 ! "数据 库 连 接 成 功 ! <br> 连 接 句柄 为 .$SconnDb-> | 
getConnId():; /打印 连接 句柄 | 
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多 学 两 招 : 

通过 “set names utf8” 语 和 句 动态 设置 数据 库 的 字符 集 为 UTF-8 编码 。 

在 对 数据 库 内 容 进 行 检索 输出 时 ， 有 时 可 能 会 出 现 乱 码 现象 ， 一 般 都 是 数据 库 字符 集 
设置 存在 偏差 所 致 的 ， 为 了 避免 上 述 情 况 的 发 生 ， 可 以 在 执行 数据 库 查 询 语句 前 执行 “set 
names 编码 ”语句 ， 在 开发 项 目 时 ， 为 了 便于 国际 化 ， 建 议 应 用 UTF-8 编码 。 


”脚下 留神 : 


设置 MySQL 数据 库 为 UTF-8 编码 所 执行 的 语句 应 该 为 “set names utf8”， 而 非 “set 


| names utf-8”， 即 “utf” 和 “8” 之 间 没 有 “-”。 


| 技术 要 点 


在 PHP 面向 对 象 的 编程 方式 中 ， 当 函数 被 定义 在 类 中 ， 就 被 称 为 成 员 方法 ， 成 员 方法 
的 功能 应 该 匹配 该 类 的 特定 功能 。 


(1) 函数 名 称 不 区 分 大 小 写 ， 例 如 myfun0 与 Myfun0) 指 的 是 同一 个 函数 。 

(2) 函数 的 参数 没有 限制 ， 可 以 定义 任意 个 需要 的 参数 

(3) 函数 名 称 理论 上 可 以 使 用 汉字 ， 但 汉字 是 双 字 节 字 符 ， 为 了 避免 出 现 无 法 预知 
的 问题 ， 尽 量 不 使 用 。 


实例 207 数据 统计 类 中 定义 求 数值 平方 的 方法 
( 实例 位 置 配套 资源 \SL\12\207 ) 
实例 说 明 


运行 本 实例 ， 如 图 12.3 所 示 。 首 先 在 图 的 文本 框 中 答 
入 一 组 数字 并 用 半角 逗号 分 割 ， 然后 单 击 “计算 ”按钮 将 在 | 可 Rs 


页 面 中 打印 出 该 组 数字 的 平均 值 。 [EE ] | 
实现 过 程 该 组 数字 的 平均 败 为 20 


(1) 建立 数据 统计 类 Stat， 并 在 类 体内 定义 静态 方法 ”图 12.3 计算 一 组 数 的 平均 值 
getAvg(0) 用 来 实现 求 多 个 数字 的 平均 值 ， 其 实现 代码 如 下 : 


class Stat 
public static fnction getAvg ($arryNum) // 定 义 静 态 方法 来 求 平均 值 
{ 
S$totalNum = count($arryNum); // 获 得 数字 总 数 
if($totalNum — 0) { /如 果 数 字 个 数 为 0 则 返回 null 
Tetum null; 
Yelset 
$sum = 0; // 用 变量 $sum 保存 所 有 数字 的 和 
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for ($i= 0:; $i < $totalNum: $i ++) { // 通 过 循环 计算 所 有 数字 的 和 
$sum += $aryNum[$i]: 


} 
retum $sum / $totalNum: // 返 回 平均 数 
} 
} 
上 述 代码 用 于 实现 求 平均 数 的 getAvg0 方 法 中 ,为 了 能 够 实现 求 任意 个 数字 的 平均 数 ，| 
将 数组 作为 参数 ， 这 样 只 要 求 得 该 数组 所 有 元 素 的 平均 值 即 可 ， 在 具体 实现 过 程 中 ， 首 先 | 
使 用 函数 count0 计 算数 组 元 素 的 个 数 ， 然 后 使 用 for 循环 语句 计算 数组 中 所 有 元 素 的 和 ， | 
最 后 使 用 returm 语句 返回 所 求 得 的 平均 数 。 | 
(2) 建立 数字 录入 表单 ， 当 用 户 单 击 表单 中 的 “计算 ”按钮 时 ， 将 通过 如 下 代码 计 | 
算 在 表单 中 所 录入 数字 的 平均 数 。 | 
iisset($_ POST[nums']) && trim($_POST['nums")D)!="){ // 判 断 是 否 已 经 提交 表单 


require 'Stat.php'; // 包 含 数据 统计 类 
S$arrayNum = explode(',, $ POST[mums']); /将 提交 数字 保存 到 数组 中 


echo ' 该 组 数字 的 平均 数 为 '. Stat::getAvg($arrayNum); 。”// 调 用 统计 类 的 静态 方法 getAvg0 | 
求 平均 数 | 
} | 
上 述 代码 中 , 首先 判断 用 户 是 否 提交 了 表单 , 如 果 是 则 首先 使 用 require 语句 包含 数据 
统计 类 ， 然 后 使 用 函数 explode0 用 半角 逗号 分 割 所 提交 数字 字符 串 ， 最 后 调用 数据 统计 类 | 
的 静态 方法 getAvg0 计 算 所 录入 数字 的 平均 数 。 | 


指点 迷津 ， | 
函数 explode0 用 于 实现 将 字符 事 以 指定 的 字符 或 子 事 分 害 ， 并 将 分 审结 果 保存 到 数组 中 ， | 


多 学 两 招 : 
为 了 提高 代码 运行 效率 ， 建 议 将 countO 函 数 放 在 循环 体外 。 
本 实例 计算 数组 中 所 有 元 素 的 和 可 以 有 两 种 写法 ， 分 别 如 下 : 
将 函数 count0 写 在 for 循环 体内 : 
for($i=0; $i<count($arrayNunm): $i++){} 
将 函数 count0 写 在 for 循环 体外 : 


$count = count($arrayNum); 
for($i=0; $i<$count; $i++) i 
查看 上 述 两 种 写法 可 知 ， 第 一 种 写法 在 执行 每 次 循环 时 都 需要 执行 一 次 函数 count()， 
而 第 二 种 写法 只 在 执行 循环 前 执行 一 次 通 数 count0， 所 以 在 程序 开发 过 程 中 ， 建议 采用 第 | 
二 种 写法 ， 可 以 提高 程序 运行 效率 。 | 


技术 要 点 
实现 本 实例 时 ， 由 于 该 类 只 包含 一 个 用 于 计算 平均 数 的 方法 ， 所 以 在 实现 该 类 时 将 求 


“27 


| 引用 。 


| 实例 说 明 


| 用 设置 汽车 颜色 的 方法 和 设置 汽车 品牌 的 方 
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平均 数 的 方法 定义 为 静态 方法 ， 这 样 在 该 类 的 情况 下 通过 类 名 即 可 直接 调用 该 方法 。 

在 PHP 面向 对 象 编程 方式 中 ,静态 方法 隶属 于 某 个 类 ， 但 不 受 类 的 束缚 ， 可 以 直接 被 
外 部 访问 。 与 定义 类 中 普通 方法 相 比 ， 定 义 静 态 方法 时 需要 使 用 static 关键 字 进行 修饰 ， 
其 定义 格式 如 下 所 示 : 


public static function 方法 名 0 


// 该 方法 实现 的 功能 
} 


在 类 体内 部 调用 该 方法 时 ,使 用 self 关键 字 加 “::” 调 用 ,在 类 外 直接 使 用 类 名 加 “::” 


实例 208 使 用 $this 关键 字 调 用 汽车 类 自身 的 方法 


( 实例 位 置 : 配套 资源 \SL\12W208 视频 位 置 : 配套 资源 \SP\12\208 ) 


本 实例 通过 $this 关键 字 在 汽车 类 内 部 调 


| 请 选择 题 色 ， 
打 色 个 ”白色 个 ”黑色 G 宝石 蓝 ，C 


| 法 来 输出 汽车 的 信息 。 运 行 本 实例 , 如 图 12.4 。 | wasxa， 
| 所 示 ， 分 别 选择 表单 中 的 颜色 和 类 型 单 选 按 | 地 3 a 


提交 


| 钮 ， 然 后 单 击 “ 提 交 ” 按 钮 即 可 在 图 中 打印 。 了 。 


| 出 汽车 信息 。 
| 实现 过 程 


图 12.4 打印 汽车 信息 


具体 步骤 如 下 : 
(1) 定义 汽车 类 Car。 首 先 在 该 类 中 定义 汽车 颜色 标识 和 汽车 类 别 标识 两 个 属性 ， 然 


后 使 用 构造 函数 对 这 两 个 属性 进行 初始 化 ， 并 在 类 内 定义 getColor() 方 法 和 getType0 方 法 ， 
| 分 别 用 来 获取 汽车 颜色 和 汽车 类 型 ， 最 后 使 用 getInfo0 方 法 打印 出 汽车 信息 。 本 实例 的 汽 


车 类 实现 代码 如 下 : 
class Car /定义 汽车 类 
{ 
private $colorFlag; 1/ 颜色 标识 
private $typeFlag; // 类 型 标识 
public function __ construct ($colorFlag, $typeFlag) /构造 方法 
Sthis->colorFlag = $colorFlag: /颜色 标识 初始 化 
Sthis->typeFlag = $typeFlag: // 类 型 标识 初始 化 
| 
public function getColor 0 // 定 义 获取 颜色 方法 
switch ($this->colorFlag) { /使 用 switch 语句 根据 不 同 颜色 获得 标识 颜色 
case 0: 
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$color = ' 红 色 '; 


Case 2: 
$color = 黑色 '; 
break:; 
default: | 
$color= ' 宝 石 蓝 '; 
} | 
Tetum $color; 


public function getType | /定义 获得 汽车 类 型 方法 
{ 
switch ($this->typeFlag) { // 根 据 类 型 标识 获得 汽车 类 型 


case 0: 
$type = ' 弃 驰 ': 
break: 
case 1: 
$type 二" 宝马; 
break: 
case 2: 
$type = ' 奥 迪 ': 
break; 
default: 
$type = "捷达 '; 
) 
return $type; 


} 
public function getInfo 0 // 获 得 汽车 信息 


Ietum ' 我 的 汽车 是 ' . $this->getColor() . Sthis->getTypeO; /调用 类 内 方法 返回 汽车 信息 


} 
} 
(2) 建立 汽车 属性 选择 表单 ， 当 用 户 单 击 表单 的 “提交 ”按钮 后 将 通过 如 下 代码 接 
收 表单 提交 的 颜色 标识 和 类 别 标识 ， 然 后 使 用 new 关键 字 对 汽车 类 进行 实例 化 ,最 后 使 用 
实例 化 的 汽车 类 的 对 象 调用 该 类 的 getInfo0 方 法 打印 汽车 信息 。 | 


iflisset($_ POST['color']) && isset($_ POST[Ytype])){ /判断 是 否 提交 了 表单 | 
require 'Car.php': // 包 含 汽车 类 | 
$colorFlag=$ POST['color]; // 获 得 表单 提交 的 颜色 标识 |! 
S$typFlag = $_POST['type']; /获得 表单 提交 的 类 别 标识 | 
S$car = new Car($colorFlag, $typFlag); /对 汽车 类 进行 实现 化 | 
echo $car->getInfo(); /1/ 打 印 汽车 信息 | 
} | 
技术 要 点 


在 PHP 面向 对 象 编程 方式 中 ,可 以 使 用 S$this 关键 字 对 类 自身 的 属性 或 方法 进行 调用 。 
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| 总 
例如 , 已 经 在 A 类 中 定义 了 方法 fun10, 在 该 类 的 fun20 方 法 中 可 以 使 用 如 下 方式 对 fun10 
| 进行 调用 。 
| class A 


内 | { 
傅 =-] | private function func10 
| f 
本 


public function fun20 


{ 
S$this->fun10; /调用 fonl10 


} 
) 


实例 209 ”学生 类 中 使 用 构造 方法 为 学 生 信 息 初始 化 


( 实例 位 置 : 配套 资源 \SL\12\209 ) 


| 实例 说 明 

| 木 实例 采用 二 维 数组 模拟 数据 库存 储 学 生 信息 ， 然 后 通过 for 循环 语句 实例 学 生 类 ， 
”并 通过 构造 方法 为 学 生 关 的 属性 赋 初 值 ， 最 后 通过 类 的 getxxx0 方 法 获得 学 生 属性 ， 并 将 
学生 信 息 输出 在 页 面 ， 如 图 12.5 所 示 。 


0312310 直 员 | 。 | 北京 西城 区 
0312311 小 张 16 | 北京 宣武 区 
olzalz | 4 起 | 17 | 北京 海 汽 区 | 


图 12.5 学 生 信息 列表 


| 实现 过 程 


具体 步骤 如 下 : 
(1) 首先 建立 二 维 数组 $students 用 来 模拟 数据 库 ， 代 码 如 下 : 
$students = array( // 二 维 数组 ， 模 拟 数据 库 


0 => array(0312310', "小 明 ', '16', "北京 西城 区 ') ， 

1 => array(0312311', "小 张 ', '16', "北京 宣武 区 ') ， 

2 => array(0312312', ' 小 赵 ', '17', ' 北 京 海淀 区 ') 
jE 
| (2) 定义 学 生 类 Student, 在 该 类 中 使 用 构造 方法 _construct0 实 现 对 学 生 信 息 的 初始 
| 化 ， 然 后 针对 类 的 各 个 属性 建立 相应 的 getXxx0 方 法 来 获取 属性 的 值 ， 代 码 如 下 : 


class Student 

{ 
private $id; /学 生 也 
private $name; // 学 生 名 称 
private $age; // 学 生年 龄 


了 。330 。 


第 12 章 ”面向 对 象 编程 一 C33 | | 
c 


private $address; /| 学生 住址 
public function ”construct ($id, $name, $age, $address) ”// 构 造 方 法 ， 对 学 生 信息 初始 化 
{ 

$this->id = $id; 


S$this->name = $name; 
S$this->age = $age; 
S$this->address = $address; 


ee function getld 0 // 获 得 学 生 了 D | 
: return $this->id; 
人 function getName () // 获 得 学 生 名 称 | 
, return $this->name; 


} 
public function getAge 0 // 获 得 学 生年 龄 
{ 


Tetum $this->age; 


} 
public function getAddress 0 // 获 得 学 生 住址 
{ 
Tetum $this->address; 
} 
} | 
(3) 通过 for 循环 语句 遍历 保存 学 生 信息 的 $students 数组 ,遍历 过 程 中 将 学 生 信息 保 | 
存 到 Student 学 生 类 中 ， 并 通过 该 类 实例 的 对 象 调用 类 中 相应 的 getXxx0 方 法 ， 获 取 学 生 
信息 。 实 现 该 过 程 的 代码 如 下 : 
<2php 
require 'arrayDb.php'; 
Tequire 'Student.php'; 
$count = count($students): 
?> 
<table border="0" align="center" cellpadding="0" cellspacing="1" bgcolor="#009933"> 
<tr> | 
<td width="100" height="22" bgcolor="#009933"><font color="#EFFFFF"> 学 号 </font></td> 
<td width="100" bgcolor="#009933"><font color="#FFFFFF"> 姓 名 </font></td> | 
<td width="100" bgcolor="#009933"><font color="#FFFFFF"> 年 龄 </font></td> 
<td width="200" bgcolor="#009933"><font color="#FFFFFF"> 住 址 </font></td> 
</tr> 
<?php 
for ($i1=0; $i<$count; Si++H){ | 
$stu = $students[$1]; 
S$student = new Student($stu[0], $stu[1], $stu[2], Sstu[3]): 
> 
<tr> 
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<td height="22" bgcolor="#FFFFFF"><?= $student->getId0?></td> 
<td bgcolor="#FFFFFF"><?= $student->getName02></td> 

<td bgcolor="#FFFFFF"><?= $student->getAge()?></td> 

<td bgcolor="#FFFFFF"><?= $student->getAddress(?></td> 


4 


| <2php 
| 多 学 两 招 ; 


PHP5.0 中 构造 方法 名 称 以 双 下 划 线 开头 。 


| 在 使 用 PHP5.0 的 构造 方法 时 ， 一 定 要 注意 构造 方法 “constructO 是 以 双 下 划 线 开头 ， 
| 而 非 单 下 划 线 。 


| 构造 方法 是 类 中 的 一 个 特殊 函数 ， 当 创建 一 个 类 的 实例 时 ， 将 会 自动 调用 类 的 构造 方 
| 法 。 在 PHP5.0 以 前 的 版 本 中 构造 方法 名 称 与 类 名 相同 , 在 PHP5.0 以 后 的 版 本 中 统一 使 用 
| _constructO 作 为 构造 方法 名 称 ， 使 用 构造 方法 应 该 注意 如 下 两 点 ; 
| 回 ”构造 方法 没有 返回 值 类 型 和 返回 值 ， 这 是 因为 构造 方法 是 在 创建 对 象 时 自动 调用 
的 ， 并 不 是 一 个 独立 的 函数 ， 因 此 不 需要 返回 值 。 
回 ”构造 方法 的 主要 功能 是 实现 对 类 的 初始 化 工作 。 


实例 210 汽车 类 使 用 public 关键 字 定义 汽车 的 行驶 方法 


( 实例 位 置 : 配套 资源 \SL\12\210 ) 


实例 说 明 

| 本 实例 用 于 展示 在 类 体外 、 类 | th 通 汽 车 类 对 外调 用 汽车 尖 的 行驶 方 法 的 结果 : 

| 内 部 的 方法 中 和 类 的 子 类 中 调用 被 人 

! 网 (2) 通过 汽车 类 的 getStatus0 方 法 调用 汽车 行驶 方法 的 结果 ; 

| public 关键 字 所 修饰 的 方法 的 结 汽车 目前 正在 行 

| 果 ， 如 图 12.6 所 示 。 (3) 通过 汽车 类 的 子 类 调用 汽车 类 的 汽车 行驶 方法 的 结果 ， 

| 上 汽车 行驶 

| 实现 过 程 , 

| 图 12.6 被 public 关键 字 修 饰 的 方法 在 不 同 范围 内 被 调用 
具体 步骤 如 下 : 


| (1) 首先 建立 汽车 类 Car， 并 在 该 类 内 部 定义 汽车 行驶 方法 ran0 以 及 获得 汽车 状态 
| 的 方法 getStatus0， 然 后 定义 类 SmallCar， 使 该 类 继承 自 类 Car， 并 在 该 类 中 定义 
| smallCarRun() 方 法 。 实 现 该 过 程 的 代码 如 下 : 


class Car /定义 汽车 类 Car 
§ 
public function run 0 // 定 义 行驶 方法 
Tetum "行驶"; 
} 


避 。332 。 


第 12 章 面向 对 象 编程 


public function getStatus 0 /定义 返回 汽车 状态 方法 
{ 

Tetum 汽车 目前 正在 '. Sthis->run0; 
} 


} 
// 定 义 小 汽车 类 SmallCar， 并 使 其 继承 汽车 类 Car 
class SmallCar extends Car 


public function smallCarRun 0 // 定 义 小 汽车 行驶 方法 


Tetum ' 小 汽车 '. $this->run(; 
} 
} 
(2) 打印 在 不 同 范围 内 调用 汽车 类 的 行驶 方法 的 结果 ， 代 码 如 下 : 
require 'Car.php'; 
$car = new Car(); 
echo' (1) 通过 汽车 类 对 象 调用 汽车 类 的 行驶 方法 的 结果 : <br/>'; 
echo $car->run() . '<br/>"; 
echo' (2) 通过 汽车 类 的 getStatus0 方 法 调用 汽车 行驶 方法 的 结果 : <br/>'; 
echo $car->getStatus() . '<br/>"; 
echo' (3) 通过 汽车 类 的 子 类 调用 汽车 类 的 汽车 行驶 方法 的 结果 : <br/>'; 
$smallCar = new SmallCar():; 
echo $smallCar->smallCarRun0 . '<br/>"; 


技术 要 点 | 

在 PHP5.0 面向 对 象 的 编程 中 ， 被 关键 字 public 修饰 的 方法 被 称 为 公有 方法 。 公 有 方 | 
法 可 以 被 类 实例 的 对 象 在 类 内 部 以 及 类 的 子 类 中 被 调用 。 | 
实例 211 使 用 private 关键 字 定义 汽车 的 颜色 属性 


( 实例 位 置 : 配套 资源 \SL\12\211 ) 


实例 说 明 | 

本 实例 主要 通过 在 不 同 范围 内 调用 类 中 私有 属性 来 演示 私有 成 员 的 作用 范围 。 运 行 本 
实例 ， 如 果 通 过 类 实例 后 的 属性 直接 调用 类 的 私有 属性 , 将 在 页 面 中 打印 如 图 12.7 所 示 的 | 
错误 信息 。 如 果 通 过 类 中 方法 调用 类 的 私有 属性 将 输出 汽车 的 颜色 ， 如 图 12.8 所 示 。 | 


通过 类 实例 的 对 象 调用 类 的 私有 属性 的 结果 : 


Fatal error: Cannot access private property Car-$color 在 类 中 的 方法 中 调用 类 的 私有 属性 的 结果 : 
in D:\App ServannwiMR\OT'O1 l\indexplp on line 17 汽车 颜色 是 : 红色 
图 12.7 通过 对 象 调用 类 中 私有 属性 图 12.8 ”通过 类 中 方法 调用 类 的 私有 属性 
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具体 步骤 如 下 : 
(1) 首先 定义 汽车 类 Car, 在 汽车 类 中 定义 私有 属性 Scolor， 并 通过 构造 方法 为 $color 
属性 进行 初始 化 ， 最 后 定义 getColor0 方 法 返回 汽车 颜色 的 值 。 该 过 程 实现 代码 如 下 : 


class Car /定义 汽车 类 Car 
private $color; /汽车 颜色 
public function __ construct ($color) // 构 造 方法 对 类 中 属性 初始 化 
, Sthis->color = $color; /汽车 颜色 初始 化 
Le function getColor 0 /定义 获得 汽车 颜色 的 方法 
。 Teturm $this->color; /返回 汽车 颜色 
} 


(2) 对 汽车 类 进行 实例 化 ， 并 指定 汽车 颜色 为 红色 ， 然 后 通过 实例 的 对 象 调用 汽车 


| 类 中 的 getColor0 方 法 获得 汽车 颜色 ， 该 过 程 实现 代码 如 下 所 示 。 在 下 述 代码 中 ， 被 注释 
| 的 代码 用 于 实现 通过 类 实例 的 对 象 调用 类 中 私有 成 员 的 结果 ， 如 果 去 掉 注 释 将 出 现 如 
| 图 12.7 所 示 的 错误 提示 ， 从 而 说 明 类 中 的 私有 方法 不 能 被 类 实例 的 对 象 所 调用 。 


| 技术 要 点 


require 'Car.php'; // 包 含 汽 车 类 
$color = ' 红 色 '; /指定 汽车 颜色 
$car = new Car($color); // 对 汽车 类 实例 化 


/echo ' 通 过 类 实例 的 对 象 调用 类 的 私有 属性 的 结果 : <br/>'; 

/echo @ 汽 车 颜色 是 : '.$car->color'<br/>' or die(' 不 能 通过 类 的 对 象 调用 类 中 的 私有 方法 <br/>'); 
echo ' 在 类 中 的 方法 中 调用 类 的 私有 属性 的 结果 : <br/>'; 

echo ' 汽 车 颜色 是 :'.$car->getColor0.'<br/>'; /打印 汽车 颜色 


在 PHP5.0 面向 对 象 的 编程 中 ， 被 关键 字 private 修饰 的 成 员 被 称 为 私有 成 员 ， 私 有 成 


| 员 可 以 在 类 体内 被 调用 ， 但 不 可 以 被 类 实例 的 对 象 和 关 的 子 类 所 调用 。 


实例 说 明 


实例 212 使 用 protected 关键 字 定 义 汽车 的 保修 年 限 


( 实例 位 置 : 配套 资源 \SL\12\212 ) 


本 实例 主要 用 于 说 明 类 中 的 保护 成 员 在 不 同 范围 内 被 调用 的 结果 。 运 行 本 实例 ， 当 使 


用 类 实例 的 对 象 调用 类 中 的 保护 属性 时 , 将 出 现 如 图 12.9 所 示 的 错误 提示 。 然 后 注释 掉 通 
| 过 类 对 象 调用 类 体内 保护 属性 的 代码 ， 并 分 别 通过 在 类 体内 和 类 的 子 类 中 调用 类 的 保护 属 


性 ， 再 次 运行 该 实例 将 出 现 如 图 12.10 所 示 的 页 面 。 
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通过 类 实例 的 对 象 直接 调用 类 中 的 保护 成 员 的 结果 | 
在 类 体内 调用 保护 成 员 的 结果 | 
Fatalerror Cannot access protected property 汽车 保修 年 限 为 3 年 | 
Car-$repairTime in D:\AppServinneiMRIOT'O12 在 类 子 类 中 调用 保护 成 员 的 结果 | 
\indexplp online 17 小 汽车 保修 年 限 为 :5 年 | 
图 12.9 通过 对 象 调用 类 中 保护 成 员 图 12.10 ”通过 子 类 调用 父 类 的 保护 成 员 
具体 步骤 如 下 : 


性 ,然后 使 用 构造 方法 对 该 属性 进行 初始 化 ,同时 定义 获得 汽车 保修 时 间 的 getRepairTime() 
方法 。 在 汽车 类 的 子 类 SmallCar 中 使 用 构造 方法 调用 其 父 类 的 构造 方法 ， 从 而 实现 对 父 类 
的 保修 时 间 属 性 进行 初始 化 ， 最 后 在 SmallCar 类 中 定义 getSmallCarRepairTime() 方 法 返回 
小 汽车 的 保修 时 间 。 实 现 该 过 程 的 代码 如 下 : | 


(1) 定义 汽车 类 Car 以 及 该 类 的 子 类 SmallCar。 在 汽车 类 中 定义 汽车 的 保修 时 间 属 


class Car // 定 义 汽车 类 Car 
| Protected $repairTime; /汽车 保修 时 间 属 性 

public function __ construct (SrepairTime) // 构 造 方法 对 汽车 的 保修 时 间 进 行 初始 化 

. Sthis->repairTime = $repair Time; 

2 function getRepairTime 0 // 获 得 汽车 保修 时 间 的 方法 

retum $this->repairTime; | 

! 
SmallCar extends Car /定义 汽车 类 的 子 类 SmallCar | 
function construct (SrepairTime) 


parent:: ”construct($repairTime); 。 // 调 用 父 类 构造 方法 对 保修 时 间 属 性 进行 初始 化 


{ 
} 


) 
public function getSmallCarRepairTime 0 /调用 父 类 的 保修 时 间 属 性 | 

Tetum $this->repairTime: | 
} 


(2) 使 用 new 关键 字 对 汽车 类 Car 进行 实例 化 ， 然 后 分 别 打 印 出 在 不 同 范围 内 调用 | 
汽车 类 保护 属性 SrepairTime 的 结果 。 代 码 如 下 所 示 : | 


SrepairTime = 3; // 定 义 保修 年 限 | 


require 'Car.php'; // 包 含 汽车 类 
Scar =new Car($repairTime); // 对 汽车 类 实例 化 
/echo ' 通 过 类 实例 的 对 象 直接 调用 类 中 的 保护 成 员 的 结果 <br/>'; 
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/lecho "汽车 保修 年 限 为 : '.$car->repairTime.' 年 <br/>'; 

echo ' 在 类 体内 调用 保护 成 员 的 结果 <br>'; 

echo 汽车 保修 年 限 为 : .$car->getRepairTime0.' 年 <br/>': 

echo ' 在 类 子 类 中 调用 保护 成 员 的 结果 <br/>'; 

SrepairTime = 5; // 定 义 保修 年 限 
$smallCar = new SmallCar($repair Time); 

echo ' 小 汽车 保修 年 限 为 :'.$smallCar->getSmallCarRepairTime0.' 年 <br/>'; 


”技术 要 点 


在 PHP5.0 面向 对 象 的 编程 中 ， 被 关键 字 protected 修饰 的 成 员 被 称 为 保护 成 员 ， 保 护 


| 成 员 可 以 在 类 体内 以 及 类 的 子 类 被 调用 ， 但 不 可 以 在 类 体外 被 调用 。 


实例 213 羊 果子 类 继承 水 果 父 类 


( 实例 位 置 : 配套 资源 \SL\12\213 ) 


| 实例 说 明 


| 获得 水 果 颜 色 和 水 果 形 状 的 方法 ， 然 后 定义 水 果 类 
| 的 子 类 苹果 类 ， 在 苹果 类 中 只 定义 构造 方法 用 于 实 人 
| 现 对 类 进行 初始 化 ， 然 后 通过 调用 父 类 的 方法 获得 | 

| 苹果 的 颜色 和 形状 。 我 看 见 的 于 果 是 ， 红色， 固形 的 


| 入 草 果 的 颜色 和 形状 属性 ， 然 后 单 击 “提交 ”按钮 


本 实例 首先 定义 父 类 水 果 类 ， 并 在 该 类 中 定义 


请 输入 苹果 的 颜色 ， 盾 色 
EE 这 


运行 本 实例 , 如 图 12.11 所 示 , 首先 在 表单 中 输 。。 图 1211 打印 划 果 的 硕 色 和 形状 属性 


| 即 可 在 页 面 中 打印 出 苹果 的 颜色 和 形状 属性 。 


具体 步骤 如 下 : 

(1) 定义 水 果 类 Fmit, 在 该 类 中 定义 颜色 属性 $color 和 形状 属性 $shape， 并 通过 构造 
方法 对 这 两 个 属性 进行 初始 化 ， 然 后 定义 用 于 获得 这 两 个 属性 的 getColor0 方 法 和 
getShape( 方 法 。 代 码 如 下 : 


class Fruit /定义 水 果 类 

private $color; /颜色 属 性 
private $shape: /形状 属性 
public function construct ($color, $shape) // 构 造 方法 对 水 果 类 初始 化 
上 

S$this->color = $color: 

$this->shape = $shape; 
} 
public function getColor 0 // 获 得 水 果 颜 色 
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Tetum $this->color; 
} 
public function getShape 0 /1/ 获 得 水 果 形 状 
{ 
return $this->shape; 
} 


} | 
(2) 定义 苹果 类 Apple， 使 该 类 继承 自 水 果 类 Fruit， 并 定义 苹果 类 的 构造 方法 ， 在 
构造 方法 中 使 用 parent 关键 字 调 用 父 类 构造 方法 对 父 类 进行 初始 化 。 代 码 如 下 : | 


class Apple extends Fruit 1/ 苹果 类 继承 水 果 类 
public function __ construct ($color, $shape) // 构 造 方法 对 类 进行 初始 化 
parent::_ construct($color, $shape); 

. } 


(3) 建立 苹果 颜色 和 形状 录入 表单 。 用户 在 表单 中 输入 荚果 的 颜色 和 形状 后 单 击 < 所 | | 
交 ” 按 钮 ， 将 通过 如 下 代码 打印 苹果 的 颜色 和 形状 属性 。 | 


ifisset($_ POST['color]) && $ POST['color']!="){ /判断 是 否 已 经 提交 表单 
require Fruit.php'; // 包 含水 果 类 
$apple = new Apple($_ POST['color],$_ POST['shape]); /对 水 果 类 进行 实例 化 | 
echo' ”<font color="blue"> 我 看 见 的 苹果 是 : .$apple->getColor0."，'.$apple->getShape0.' 的 | 
</font>'; // 打 印 苹果 属性 | 
} 


上 述 代 码 首先 判断 用 户 是 否 已 经 提交 表单 ， 如 果 是 则 首先 使 用 require 语句 包含 苹果 | 
类 ,然后 使 用 new 关键 字 对 苹果 类 进行 实例 化 ,最 后 使 用 侠 果 类 实例 的 对 象 调用 父 类 中 的 | 
getColor() 方 法 和 getShape() 方 法 打印 苹果 的 属性 。 | 


在 PHP5 0 面向 对 象 编程 方式 中 , 可 以 使 用 extends 关键 字 继 承 指定 的 父 类 。 代码 如 下 ， | 
class Parentl // 定 义 父 类 Parentl | 
// 父 类 的 成 员 
i Child extends Parentl // 定 义 子 类 Child 
// 子 类 的 成 员 
} 


通过 上 述 继承 关系 ， 即 可 在 子 类 中 使 用 parent 关键 字 加 “::” 操 作 符 调用 父 类 的 公有 
方法 或 属性 ， 或 者 重 写 非 final 关键 字 修饰 的 方法 。 
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实例 214 使 用 parent 关键 字 调 用 父 类 的 方法 


( 实例 位 置 : 配套 资源 \SL\12W214) 


ee 实例 说 明 


本 实例 主要 使 用 parent 关键 字 在 小 汽车 类 中 


| 调用 汽车 类 的 行驶 方法 。 运 行 本 实例 ， 如 图 12.12 fi 
| 所 示 ， 分 别 在 页 面 中 打印 出 通过 汽车 类 调用 其 自 小 汽车 可 以 行驶 
| 身 的 行驶 方法 和 其 子 类 小 汽车 类 调用 其 自身 的 行 图 12.12 打印 汽车 和 小 汽车 的 行驶 方法 
| 驶 方法 的 结果 。 
| 实现 过 程 实现 过 程 
具体 步骤 如 下 : 
(1) 定义 汽车 类 ， 并 在 该 类 中 定义 汽车 的 行驶 方法 ， 代 码 如 下 : 
class Car /定义 汽车 类 
{ 
public function run 0 /定义 行驶 方法 
retum ' 行 驶 ': 
} 
} 


| (2) 定义 小 汽车 类 使 其 继承 自 汽 车 类 ， 在 类 体内 定义 smallCarRun0 方 法 ， 并 在 该 方 
| 法 中 使 用 parent 关键 字 调 用 汽车 类 的 un0 方 法 ， 代 码 如 下 : 
| TS /定义 小 汽车 类 ， 使 之 继承 自 汽车 类 

{ 


public function smallCarRun 0 /定义 小 汽车 行驶 方法 
retum ' 小 汽车 可 以 '. parent::run(); 
} 
} 
| (3) 使 用 require 语句 包含 Carphp 文件 , 然后 分 别 对 汽车 类 Car 和 小 汽车 类 SmallCar 
| 进行 实例 化 ， 然 后 分 别 调用 这 两 个 类 的 行驶 方法 ， 代 码 如 下 : 


require 'Car.php'; // 包 含 汽 车 类 
$car =new Car0: /对 汽车 类 进行 实例 化 
echo $car->run() . '<br/>"; // 调 用 汽车 类 行驶 方法 
S$smallCar = new SmallCar0): /实例 小 汽车 类 
| echo $smallCar->smallCarRunO):; /调用 小 汽车 类 的 行驶 方法 
| 技术 要 点 


| 在 PHP5.0 面向 对 象 的 编程 方式 中 使 用 parent 关键 字 加 操作 符 “::” 调 用 父 类 的 方法 ， 
J 。338 。 
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调用 过 程 如 下 所 示 : 
class Parentl // 定 义 父 类 
public function funParentO{ // 定 义 父 类 的 funParent0 方 法 
} 
} 
class Child extends Parentl // 定 义 子 类 
public function funChildO{ // 定 义 子 类 的 funChild0 方 法 
parent::funParent(); // 调 用 父 类 的 方法 
} 
} 


使 用 parent 关键 字 不 仅 可 以 调用 父 类 的 普通 方法 ,而 且 可 以 通过 调用 父 类 的 构造 方法 
实现 对 父 类 的 初始 化 。 | 


实例 215 革 果 子 类 中 覆盖 水 果 父 类 中 的 方法 


( 实例 位 置 : 配套 资源 \SL\12\215 ) 
实例 说 明 


本 实例 主要 通过 在 苹果 类 中 重 写 其 父 类 水 果 类 的 getColor0 方 法 来 讲解 如 何 应 用 类 的 
重 写 机 制 。 运 行 本 实例 ， 如 图 12.13 所 示 ， | 


其 中 第 一 行为 通过 水 果 类 调用 其 自身 的 不 同 的 水 果 颜 色 不 同 ， 无 法 确定 
getColor() 方 法 的 输出 结果 ， 第 二 行为 苹果 蕴 果 的 颜色 是 红色 


类 调用 其 自身 的 getColor0 方 法 的 输出 结 
果 ， 并 且 该 方法 重 写 了 其 父 类 水 果 类 的 
getColor() 方 法 。 
实现 过 程 
具体 步骤 如 下 : | 
(1) 定 义 水 果 类 Fmit, 并 在 该 类 中 定义 getColor0 方 法 ,然后 定义 水 果 类 的 子 类 Apple， | 
使 该 类 继承 自 水 果 类 Fruit， 在 苹果 类 Apple 中 重 写 其 父 类 的 getColor0 方 法 。 实 现 该 过 程 | 
的 代码 如 下 : | 


图 12.13 重 写 水 果 类 中 的 getColor0 方 法 的 结 ! 


class Fruit // 定 义 水 果 类 
public function getColor 0 // 获 得 水 果 颜 色 
retum ' 不 同 的 水 果 颜 色 不 同 ， 无 法 确定 '; 
} 

有 Apple extends Fruit // 华 果 类 继承 水 果 类 
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4{ 


private $color; // 定 义 苹果 颜色 属性 
public function __ construct ($color) // 构 造 方法 对 类 进行 初始 化 
| 上 
天 六 | S$this->color = $color; 
NA | } 
| public function getColor 0 // 获 得 水 果 颜色 
{ 
| Tetum ' 苹 果 的 颜色 是 '. $this->color; 
} 
} 


| (2) 包含 Fruitphp 文件 ,然后 使 用 new 关键 字 对 Fruit 类 进行 实例 化 ， 并 通过 实例 化 
| 的 对 象 调用 该 类 的 getColor0 方 法 ， 最 后 对 Apple 类 进行 实例 化 ， 并 调用 Apple 类 中 的 
| getColor() 方 法 打印 苹果 的 颜色 。 该 过 程 的 实现 代码 如 下 所 示 : 


require Frit.php'; /包含 Fruitphp 文件 
Sfruit = new FruitO; // 对 水 果 类 进行 实例 化 
echo $fruit->getColor().'<br/>"; // 打 印 水 果 类 的 获得 颜色 方法 
$apple = new Apple(' 红 色 "); // 对 苹果 类 进行 实例 化 
| echo $apple->getColor0; /打印 苹果 类 的 获得 颜色 方法 
| 技术 要 点 


| 子 类 不 仅 可 以 调用 父 类 的 方法 ， 而 且 可 以 对 指定 的 方法 进行 重 写 ， 应 用 重 写 机 制 可 以 
| 扩展 类 中 方法 的 功能 ， 其 中 实现 对 类 中 方法 重 写 的 代码 如 下 : 


class Parentl // 父 类 Parentl 
public function fongO{ 
// 父 类 的 fun0 方 法 
} 
} 
class Child extends Parentl // 子 类 Child 继承 自 Parentl 
public function funO{ 
// 重 写 父 类 的 fun0 方 法 
} 
} 


| 对 上 述 代 码 中 的 子 类 Child 进行 实例 化 ， 然 后 使 用 实例 化 后 的 对 象 调用 类 中 的 ran() 方 
| 法 ， 将 执行 子 类 重 写 后 的 ran0 方 法 的 功能 而 非 父 类 方法 的 功能 。 


实例 216 美食 抽象 类 


( 实例 位 置 : 配套 资源 \SL\12\216 ) 
| 实例 说 明 


通过 本 实例 可 以 演示 抽象 类 不 能 被 实例 化 ， 只 能 被 继承 。 本 实例 首先 定义 抽象 的 父 类 
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美食 类 ， 然 后 定义 该 类 的 子 类 面包 类 ， 最 后 分 别 对 这 两 个 类 进行 实例 化 并 调用 获取 制作 原 | 
料 的 方法 。 运 行 本 实例 ， 将 在 页 面 打印 如 图 12.14 所 示 的 错误 提示 ， 从 错误 提示 可 知 ， 抽 | 
象 类 不 能 被 实例 化 。 | 
如 果 将 抽象 类 实例 的 代码 注释 掉 ， 再 次 运行 本 实例 ， 将 出 现 如 图 12.15 所 示 的 结果 ， | 天方 
程序 可 以 正常 运行 说 明 抽象 类 可 以 被 继承 。 | ev 
Ez 


Fatal error Cannot instantiate abstract class Food in 


DaagpServnnwMRAO7lGuinaexple on ine 15 | 制作 面包 的 材料 是 :面粉 
图 12.14 实例 抽象 类 的 错误 提示 图 12.15 调用 抽象 类 的 子 类 的 结果 
实现 过 程 
具体 步骤 如 下 : 


(1) 定义 抽象 美食 类 Food， 在 该 类 中 定义 Smaterial 属性 ， 这 
进行 初始 化 ， 然 后 定义 getMaterial( 方 法 返回 美食 的 京 制 材料 ， 代 码 如 下 : 


abstract class Food /美食 类 

{ 
Private $material; // 毫 制 材料 
public function .construct ($material) // 父 类 构造 方法 
{ 


S$this->material = $material: 


} 
public function getMaterial 0 // 获 得 美食 材料 方法 
{ 
Teturn $this->material; 
} 
} 


(2) 定义 面包 类 Bread， 并 使 其 继承 自 美食 类 Food， 然 后 在 该 类 的 构造 方法 中 使 用 
parent 关键 字 调用 父 类 的 构造 方法 实现 对 其 父 类 的 初始 化 。 该 过 程 的 实现 代码 如 下 : 


class Bread extends Food /面包 类 继承 美食 类 
public function construct ($material) // 子 类 构造 方法 
parent::_construct($material); 

. } 


(3) 使 用 require 语句 在 index.php 中 包含 Food.php 文件 ,然后 使 用 new 关键 字 对 Bread 
类 进行 初始 化 ,最 后 通过 其 实例 的 对 象 调用 getMaterial0 方 法 打印 出 制作 面包 所 需 的 材料 ， | 
代码 如 下 : | 

require Food.php': 

$material = "面粉 

//$food = new Food($material); 
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& 2 
/lecho $food->getMaterial(|).'<br/>"; 


S$bread = new Bread($material); 
echo ' 制 作 面 包 的 材料 是 : "$bread->getMaterial0.'<br/>'; 


S| 抽象 类 与 普通 类 的 区 别 在 于 ， 抽 和 象 类 不 能 被 实例 化 ， 即 不 能 用 来 创建 对 象 ， 只 能 被 继 


承 。 抽象 类 的 定义 方法 是 在 class 前 加 关键 字 abstract， 代 码 如 下 


abstract class MyClass{ 
// 类 中 的 属性 和 方法 
| 


如 果 对 抽象 类 进行 实例 化 ， 将 在 页 面 打印 如 图 12.14 所 示 的 错误 信息 。 


实例 217 学 生 类 多 重 接口 的 实现 


( 实例 位 置 : 配套 资源 \SL\12\217 ) 


| 实例 说 明 

| 本 实例 主要 介绍 PHP 面向 对 象 编程 中 接口 的 定义 、 
| 应 用 以 及 类 如 何 实现 多 个 接口 。 运 行 本 实例 , 如 图 12.16 放风 学生 本 9 IE 
”所 示 ， 首 先 在 表单 中 输入 学 生 学 号 和 学 生 姓名 ,然后 单 。 | 了 R 


| -过 | 

| 击 “ 提 交 ” 按 钮 即 可 在 页 面 中 打印 出 学 生 信息 。 学生 的 学 是 0312315 姓名 是 ol | 
| 实现 过 程 一 
| 实现 过 程 图 12.16 打印 学 生 信息 

| 具体 步骤 如 下 : 


| (1) 定义 学 生 ID 接口 ， 在 接口 中 声明 用 于 设置 学 生 ID 的 setId0 方 法 和 获得 学 生 ID 
| 的 getd0 方 法 ， 代 码 如 下 : 


interface Property Id // 编 号 接口 
public function setId ($id): /方法 声明 
public function getId (); 

} 


| (2) 定义 学 生 名 称 接口 Property_Name， 并 在 接口 中 声明 设置 学 生 姓名 的 setName0 
| 方法 或 获得 学 生 姓 名 的 getName0 方 法 ， 代 码 如 下 : 


interface Property_ Name // 名 称 接口 
{ 
public function setName ($name); // 方 法 声明 
public function getName (0: 
| 


(3) 定义 学 生 类 Student， 使 其 同时 实现 Property ID 接口 和 Property Name 接口 ， 并 
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实现 类 中 所 声明 方法 的 定义 ， 代 码 如 下 : 


class Student implements Property Id, Property Name  // 定 义学 生 类 , 使 其 同时 实现 Property Id | 
和 Property_Name 两 个 接口 | 


{ 


} 


private $id; // 编 号 属性 

private $name; // 名 称 属性 

public function setId ($id) /实现 接口 中 的 各 个 方法 
{ 


S$this->id = $id; 


} 
public function getId 0 
{ 
return $this->id; 
} 
public function setName ($name) 
{ 


S$this->name = $name; 


public function getName 0 
{ 


} 


return $this->name; 


(4) 建立 学 生 属 性 信息 录入 表单 ， 当 单 击 表单 中 的 “提交 ”按钮 后 将 通过 如 下 代码 


在 页 面 中 打印 出 所 录入 的 学 生 编号 和 学 生 名 称 。 


ifisset($_ POST[id]) && $ POST['id"]!="){ /判断 是 否 提交 了 表单 
require 'Student.php'; // 包 含 学 生 类 
$student = new StudentO; // 对 学 生 类 进行 实例 化 
$student->setId($_POST['id"]); // 设 定 学 生 了 
$student->setName($_ POST[mame']); // 设 定 学 生 名 称 


echo '<font color="green"> 当 前 学 生 的 学 号 是 : '.$student->getId0. 姓名 是 : '.$student-> | 


getName0.'</font>"， // 打 印 学 生 信息 


} 


在 上 述 代 码 中 ， 首 先 判 断 是 否 已 经 提交 了 表单 ， 如 果 是 则 首先 使 用 require 语句 包含 | 
Student.php 文件 ， 然 后 使 用 new 关键 字 对 学 生 类 Student 进行 实例 化 ， 并 调用 实例 化 后 对 | 
象 的 setXxx0 方 法 分 别 为 学 生 编号 和 学 生 姓名 赋 初 值 ， 最 后 分 别 调用 类 中 的 getXxx0 方 法 | 
打印 学 生 信息 。 | 


技术 要 点 


本 实例 的 关键 技术 是 如 何 定义 接口 ， 以 及 如 何 实现 一 个 或 多 个 接口 。 在 PHP 中 接口 使 | 
用 关键 字 interface 声明 ， 在 类 体内 不 能 有 属性 定义 ， 只 能 有 方法 声明 ， 并 且 不 能 在 方法 中 | 
定义 任何 功能 代码 。PHP 中 接口 的 定义 方法 如 下 : 


interface name 


{ 
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public function fun10; 
private function fun2($param): 
| | 
会 内 | 对 接口 定义 完成 后 ， 可 以 在 定义 类 时 使 用 关键 字 implements 来 实现 一 个 或 多 个 接口 ， 
~ | 所 实现 的 多 个 接口 名 称 之 间 使 用 逗号 分 隔 ， 例 如 ; 
ey 
| // 需 要 实现 各 个 接口 中 所 声明 的 方法 
} 


综 上 可 知 ， 实 现 接口 的 类 中 至 少 应 包括 所 实现 接口 中 所 声明 的 方法 。 


实例 218 通过 继承 实现 多 态 


( 实例 位 置 : 配套 资源 \SL\12\218 ) 


本 实例 主要 通过 继承 实现 类 的 多 态 。 在 制作 本 实例 时 ， 首 先 定 义 动物 类 Animal， 然 后 
| 分 别 定 义 企鹅 类 Penguin 和 昆虫 类 Insect， 并 在 这 两 个 子 类 中 分 别 重 写 动 物 类 的 行走 方法 ， 最 
| 后 通过 这 两 个 子 类 实例 的 对 象 调用 其 自身 的 行走 方法 将 在 页 面 打 印 如 图 12.17 所 示 的 内 容 。 
| | 
企 葛 可 以 直立 行走 
昆虫 可 以 有 私 行 


图 12.17 通过 继承 实现 类 的 多 态 


| 实现 过 程 
具体 步骤 如 下 : 
| (1) 定义 抽象 的 动物 类 Animal， 并 在 该 类 中 定义 行走 的 方法 walk0， 然 后 定义 企鹅 
| Penguin 和 昆虫 类 Insect， 使 二 者 分 别 继承 类 Animal， 并 在 这 两 个 类 中 重 写 Animal 类 中 的 
| walk0) 方 法 ， 代 码 如 下 : 


abstract class Animal // 定 义 动物 类 
public function walk 0 // 定 义 动物 类 中 的 行走 方法 
retum ' 动 物 能 行走 : 
} 
0 Penguin extends Animal // 定 义 企鹅 类 ， 并 使 其 继承 自动 物 类 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 


retum ' 企 鹅 可 以 直立 行走 '; 


} 


J Insect extends Animal // 定 义 昆虫 类 ， 并 使 其 继承 自动 物 类 
public function walk 0 // 重 写 父 类 中 的 walk0 方 法 
retum ' 昆 虫 可 以 疏 行 : 
} : | 


(2) 使 用 require 语句 包含 Animalphp 文件 , 然后 分 别 对 企鹅 类 和 昆虫 类 进行 实例 化 ， | 
并 分 别 调用 这 两 个 类 中 的 walk0 方 法 ， 代 码 如 下 : | 


require 'Animal.php'; /包含 Animalphp 文件 | 
$penguin = new Penguin0: // 对 企鹅 类 进行 实例 化 | 
echo $penguin->walk(); // 调 用 企鹅 类 的 walk0 方 法 | 
echo '<br/>': | 
S$insect = new Insect(); // 对 昆虫 类 进行 实例 化 | 
echo $insect->walk(); // 调 用 昆虫 类 的 walk0 方 法 | 


通过 上 述 实 例 的 运行 结果 可 知 ， 企 鹅 类 和 昆虫 类 虽然 都 重 写 了 父 类 的 walk0 方 法 ， 但 
在 页 面 中 打印 的 结果 却 不 同 ， 这 就 是 通过 继承 实现 类 重 载 的 体现 。 | 


本 实例 的 关键 是 如 何 通过 继承 来 实现 类 的 多 态 , 在 PHP 面向 对 象 编程 中 , 可 以 首先 定 

义 一 个 抽象 的 父 类 ， 然 后 再 定义 多 个 子 类 来 继承 该 父 类 ， 在 子 类 中 可 以 通过 方法 重 载 的 方 | 
式 来 重 写 父 类 中 的 功能 ， 这 样 就 实现 了 类 的 多 态 。 其 示例 代码 如 下 : | 
abstract class Parent // 定 义 抽象 的 父 类 Parent | 

public function fun 0 // 定 义 父 类 的 fun0 方 法 | 

retum 类 fun0 方 法 的 实现 ' | 

} | 

} | 

class Childl extends Parent /定义 子 类 Child1， 使 其 继承 Parent | 

public function fun |) // 在 Childl 中 重 写 Parent 类 中 的 fun0 方 法 

@ | 

return 'Child1 中 fan0 方 法 的 实现 '; | 

| 

} | 

class Child2 extends Parent /定义 子 类 Child2， 使 其 继承 Parent | 

public function fun 0 // 在 Child2 中 重 写 Parent 类 中 的 fun0 方 法 

{ | 

retum 'Child2 中 fun0 方 法 的 实现 '; | 

} | 

) | 
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实例 219 通过 接口 实现 多 态 


全 内 | | ( 实例 位 置 : 配套 资源 \SL\12\219 ) 
a 实例 说 明 


| 本 实例 主要 介绍 如 何 通 过 接口 来 表现 类 的 多 态 性 。 
| 制作 本 实例 时 ， 首 先 定义 动物 接口 Animal, 然后 分 别 定 


通过 接口 实现 多 态 


| 企鹅 可 以 直立 行走 

| 义 企 移 类 和 昆虫 类 来 实现 这 个 接口 ， 并 实现 接口 中 所 声 Se 

| 明 的 walk0 方 法 ， 运 行 本 实例 ， 如 图 12.18 所 示 。 

| 实现 过 程 图 12.18 通过 接口 实现 类 的 多 态 


具体 步骤 如 下 : 
| (1) 定义 动物 类 接口 Animal, 并 在 该 接口 中 声明 walk0 方 法 , 然后 定义 企鹅 类 Animal 
| 和 昆虫 类 Insect， 使 这 两 个 类 分 别 实现 Animal 接口 ， 代 码 如 下 : 


interface Animal /定义 动物 接口 

public function walk (0; /声明 行走 的 方法 

os Penguin implements Animal // 定 义 企鹅 类 ， 并 使 其 实现 动物 接口 
public function walk | // 重 写 父 类 中 的 walk0 方 法 


retum ' 企 鹅 可 以 直立 行走 '; 
} 
} 
class Insect implements Animal // 定 义 昆虫 类 ， 并 使 其 实现 动物 接口 
{ 


public function walk | // 重 写 父 类 中 的 walk0 方 法 
{ 
retum ' 昆 虫 可 以 疏 行 ” 
} 
): 


(2) 分 别 对 企鹅 类 和 昆虫 类 进行 实例 化 ， 然 后 使 用 实例 化 的 对 象 调用 类 中 的 walkO 


| 方法， 代码 如 下 : 

require 'Animal.php'; // 包 含 Animalphp 文件 
S$penguin = new Penguin(): // 对 企鹅 类 进行 实例 化 
echo $penguin->walk(): // 调 用 企鹅 类 的 walk0 方 法 
echo '<br/>': 
S$insect = new Insect(0: // 对 昆虫 类 进行 实例 化 

| echo Sinsect->walk(); /调用 昆虫 类 的 walk0 方 法 

| 技术 要 点 


| 在 继承 中 通过 方法 重 写 方式 可 以 体现 类 的 多 态 性 , 通过 接口 的 方式 同样 可 以 体现 类 的 
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interface A // 定 义 接口 A 
public function fun (); // 声 明 接口 中 的 fun0 方 法 
人 Classl implements A /定义 类 Classl 使 其 实现 接口 A 
public function fun | // 实 现 接口 A 中 的 fun0 方 法 
s retum ' 在 类 Classl 中 实现 接口 A 中 的 fun0 方 法 '; 
: } 
class Class2 implements A 
public function fun () // 实 现 接口 A 中 的 fun0 方 法 
retum ' 在 类 Class2 中 实现 接口 A 中 的 fun0 方 法 '; 
; } 


上 述 代码 中 定义 接口 A， 并 在 接口 中 声明 fun0 方 法 ， 然 后 分 别 定义 类 Classl 和 类 | 
Class2， 使 这 两 个 类 都 实现 接口 A， 并 实现 接口 A 中 的 fun0 方 法 。 从 示例 代码 中 可 知 ， 类 | 
Classl 和 类 Class2 虽然 都 实现 了 接口 A 中 所 声明 的 fun0 方 法 ， 但 这 两 个 方法 实现 的 功能 | 
却 不 同 ， 从 而 体现 类 的 多 态 性 。 | 


实例 220 使 用 final 关键 字 防 止 类 被 继承 


( 实例 位 置 : 配套 资源 \SL\12\220 ) 


实例 说 明 | 

本 实例 主要 讲解 final 关键 字 的 用 法 。 首 先 定义 水 果 类 Fruit， 然 后 定义 final 型 的 苹果 | 
类 Apple， 使 之 继承 自 水 果 类 ， 通 过 Apple 类 即 可 实现 对 荚果 属性 的 设置 。 运 行 本 实例 ， | 
如 图 12.19 所 示 ， 首 先 在 文本 框 中 输入 苹果 的 颜色 和 形状 属性 ， 然 后 单 击 “ 提 交 ” 按 钮 即 | 
可 在 页 面 中 打印 出 苹果 的 属性 信息 。 如 果 再 定义 一 个 类 ， 并 使 之 继承 final 型 的 Apple 类 ， | 
则 会 在 页 面 中 打印 出 如 图 12.20 所 示 的 错误 提示 。 | 


苹果 的 颜色 是 : 


[| 
苹果 的 形状 是 : 
苹果 的 颜色 是 : Ed| 
Ee |] Fatal error: Class Test may not 
Re inherit from final class (Appls) in 
艺 一 一 周 计 | 
D:\AppServwww\ MR\07T020 
蕴 困 是 红色 固形 的 ‘Fruitplp on line 30 


图 12.20 ”继承 final 型 水 果 类 的 错误 提示 | 
。347 。 UD 


图 12.19 打印 苹果 的 属性 
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实现 过 程 


有 具体 步骤 如 下 : 
(1) 定义 水 果 类 Fruit, 在 该 类 中 定义 水 果 颜 色 属 性 Scolor， 并 通过 构造 方法 对 颜色 属 


性 进行 初始 化 ， 然 后 定义 获得 颜色 的 getColor0 方 法 ， 代 码 如 下 : 


class Fruit /定义 水 果 类 
private $color; /定义 颜色 属性 
public function construct ($color) // 通 过 构造 方法 对 颜色 属性 进行 初始 化 
$this->color = $color; 
a function getColor 0 // 获 得 水 果 颜 色 的 方法 
{ 


return $this->color: 
} 
} 
(2) 定义 final 型 的 苹果 类 Apple， 并 使 其 继承 水 果 类 Fruit， 在 水 果 类 中 定义 苹果 的 
形状 属性 $shape， 通过 构造 方法 对 苹果 类 进行 初始 化 , 最 后 定义 getShape0 方 法 , 返回 水 果 
的 形状 ， 代 码 如 下 : 


final class Apple extends Fruit // 定 义 final 型 的 苹果 类 ， 使 之 继承 子 水 果 类 
{ 
Private $shape; // 定 义 形状 属性 
public function construct ($color, $shape) /构造 函数 
{ 
parent:: _ construct($colorn): // 调 用 父 类 构造 方法 
Sthis->shape = $shape; // 对 形状 属性 进行 初始 化 
9 
public function getShape 0 // 获 得 苹果 的 形状 方法 
{ 
return $this->shape; 
} 
) 
/* 
class Test extends Apple { /定义 一 个 Test 测试 类 ， 使 之 继承 final 型 的 Apple 类 
} 
wh 


上 述 代 码 中 ， 用 多 行 注释 的 部 分 用 于 测试 被 关键 字 final 修饰 的 类 是 否 可 以 被 继承 。 
(3) 建立 苹果 属性 录入 表单 ， 当 用 户 单 击 表单 中 的 “提交 ”按钮 后 ， 将 通过 如 下 代 
码 打印 出 苹果 的 属性 。 
iisset($_ POST['color]) && $ POST['color]!="){ 
Tequire 'Fruit.php'; 
$apple = new Apple($ POST['color'], $ POST['shape]): 
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echo '<font color="red"> 苹 果 是 '.$apple->getColor().$apple->getShape0.' 的 </font>"; 


} | 

上 述 代码 中 , 首先 判断 用 户 是 否 已 经 提交 了 表单 , 如 果 是 则 首先 使 用 require 语句 包含 

Frmuitphp 文件 ， 然 后 对 苹果 类 进行 实例 化 ， 最 后 分 别 通 过 getColor0 方 法 和 getShape( 方 法 | 

打印 出 苹果 的 属性 。 | 
技术 要 点 


通过 本 实例 的 运行 结果 可 知 ， 使 用 final 关键 字 修饰 的 类 只 能 被 实例 化 ， 不 能 被 继承 ， 
如 果 继 承 了 final 型 的 类 ， 将 在 页 面 中 打印 如 下 错误 提示 。 | 


Fatal error: Class Test may not inherit from final class (Apple) im D:\AppServwww\MR\07\020\ | 
Frit.php on line 30 | 


实例 221 使 用 static 关键 字 定义 类 的 静态 成 员 


( 实例 位 置 : 配套 资源 \SL\12\221 ) 


实例 说 明 

通过 本 实例 主要 讲解 PHP 面向 对 象 编程 方式 中 的 static 关键 字 的 用 法 ， 运 行 本 实例 ， | 
如 图 12.21 所 示 ， 首 先 在 图 中 的 文本 框 中 输入 要 计算 的 数字 ， 同 时 在 计算 类 型 列表 框 中 选 | 
择 计算 类 型 ， 然 后 单 击 “ 求 值 ”按钮 ， 即 可 在 页 面 中 打印 出 计算 结果 。 这 里 要 注意 ， 在 进 | 
行 除 运算 时 ， 如 果 除 数 为 0， 则 应 给 出 错误 提示 ， 如 图 12.22 所 示 。 | 


数值 计算 器 ; 
B 


[pa | 
求 值 cp | 
结果 :除数 不 能 为 0 
图 12.21 数值 计算 器 图 12.22 除数 为 0 时 的 提示 信息 
实现 过 程 
有 具体 步骤 如 下 : | 


(1) 定义 数值 计算 类 Math， 并 在 该 类 中 定义 用 于 进行 加 、 减 、 乘 、 除 运算 的 静态 方 | 
法 ， 在 进行 求 除 运算 中 通过 try/catch 语句 进行 除数 为 0 时 的 异 党 处理。 实现 该 过 程 的 代码 | 
如 下 : | 


class Math // 定 义 数 值 计 算 类 
public static function add (Snuml, Snum2) // 相 加 的 方法 
Teturn $numl + $num2: 
i static function sub ($numl, $num?) // 相 减 的 方法 
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让 
| Teturn $numl - $num?2; 
| } 
| public static fimction multi (Snuml, Snum2) // 相 乘 的 方法 
| { 
会 内 | return $numl * $num?; 
NA | | 
| public static function div (Snuml, $num?) // 相 除 的 方法 
{ 
| ty{ 
| 下 ($num2 一 0) 1{ /如果 除数 为 0， 则 抛 出 异常 
| throw new Exception(' 除 数 不 能 为 07; 
| }else{ 
| return $numl / Snum2; 
| } 
} catch (Exception $e) { 
return $e->getMessage(); /如 果 除 数 为 0， 则 给 出 错误 提示 
} 
h 


(2) 定义 数值 录入 表单 ， 当 在 表单 中 录入 数字 ， 并 单 击 表单 的 “ 求 值 ”按钮 后 ， 将 
通过 如 下 代码 计算 出 表单 中 所 定义 的 算数 运算 的 结果 。 


if(isset($_ POST[muml']) && trim($ POST[muml]) !=") { /判断 是 否 提交 了 表单 
require 'Math php': /包含 Math.php 文件 
$numl =$_ POST[muml']; /获得 提交 的 数字 


$num2 = $_POST['num?2"]:; 
switch ($_POST['type']) { 


case + // 进 行 加 运算 
Sresult = Math::add($numl, Snum2); 
break:; 
case '- // 进 行 减 运算 
$result = Math::sub($numl, $num2); 
break: 
Case *": // 进 行 乘 运算 
$result = Math::multi($numl, $num2): 
break:; 
case /': // 进 行 除 运算 
| $result = Math::div($numl, Snum2): 
| break; 
| } 
| echo ' 结 果 : '. $result: // 打 印 计算 结果 


| } 

| 上 述 代 码 中 ， 首 先 判 断 表 单 是 否 已 经 提交 ， 如 果 是 则 使 用 switch 语句 判断 要 进行 计算 
| 的 类 型 ， 然 后 通过 Math 类 直接 调用 其 中 的 静态 方法 进行 计算 。 
| 技术 要 点 

| 在 PHP 面向 对 象 编程 方式 中 , 使 用 static 关键 字 修 饰 的 属性 称 为 静态 属性 , 使 用 static 
| 关键 字 修 饰 的 方法 称 为 静态 方法 。 通 过 类 实例 的 对 象 可 以 调用 类 中 公有 方法 , 而 静态 成 员 的 
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特点 是 在 不 对 类 进行 实例 化 的 前 提 下 ， 直 接 通 过 类 名 即 可 对 其 进行 调用 ， 其 调用 格式 如 下 : 
类 名 :: 公 有 静态 成 员 | 


实例 222 使 用 clone 关键 字 实 现 对 象 的 克隆 


( 实例 位 置 : 配套 资源 \SL\12\222 ) 


本 实例 主要 讲解 PHP5.0 面向 对 象 编程 中 clone 关键 字 的 使 用 方法 , 运行 本 实例 , 分别 
如 图 12.23 和 图 12.24 所 示 ， 其 中 图 12.23 中 的 输出 结果 是 使 用 clone 关键 字 克 隆 对 象 后 ， | 
分 别 用 原来 对 象 和 克隆 的 对 象 对 类 中 方法 进行 重新 赋值 并 调用 的 结果 ， 而 图 12.24 为 使 用 | 
等 号 赋值 的 方式 来 产生 一 个 新 对 象 后 ， 然 后 再 分 别 使 用 新 旧 对 象 实现 对 类 中 的 方法 进行 调 | 


用 的 结果 。 
羊 的 颜色 是 灰色 羊 的 颜色 是 白色 
图 12.23 ”使 用 clone 关键 字 传递 对 象 图 12.24 ”使 用 等 号 传递 对 象 
实现 过 程 
具体 步骤 如 下 : 


(1) 建立 羊 类 Sheep， 并 在 该 类 中 定义 羊 的 颜色 属性 Scolor， 同 时 定义 用 来 设置 颜色 
的 setColor() 方 法 和 获得 颜色 的 getColor0 方 法 ， 代 码 如 下 : | 


class Sheep 

{ 
private $color; // 颜 色 属性 
public function setColor ($color) // 设 置 颜色 的 方法 
{ 


S$this->color = $color; 
} 
public function getColor 0 // 获 得 颜色 的 方法 


Ietum ' 羊 的 颜色 是 ' . $this->color; 
} 
} 


(2) 对 Sheep 类 进行 实例 化 ， 然 后 分 别 用 等 号 赋值 和 clone 的 方法 测试 对 对 象 进行 更 
改 的 影响 结果 ， 代 码 如 下 : | 


require 'Sheep.php': /包含 Sheep php 文件 

$sheep = new SheepO; // 对 Sheep 类 进行 实例 化 

/* 

$sheep->setColor(' 白 色 '); // 设 置 羊 的 颜色 

echo $sheep->getColor(): // 打 印 羊 的 颜色 

$sheepl = $sheep; // 将 $sheep 对 象 赋值 给 新 对 象 $sheep1 
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echo ‘<br/>'; 

$sheep1->setColor(' 灰 色 '); // 通 过 新 对 象 $sheep1 调用 设置 颜色 的 方法 

echo $sheep->getColor0: // 打 印 羊 的 颜色 

二 

$sheep->setColor(' 白 色 '); // 设 置 羊 的 颜色 

echo $sheep->getColorO; // 打 印 羊 的 颜色 

$sheepl = clone $sheep; // 克 隆 $sheep 对 象 ， 产 生 一 个 新 的 $sheepl 对 象 

echo '<br/>': 

$sheep1->setColor(' 灰 色 )); // 通 过 新 克隆 的 $sheep1 对 象 调用 Sheep 类 中 的 setColor0 方 法 
echo $sheep->getColor(); // 打 印 羊 的 颜色 


| 技术 要 点 


| 如 下 : 


在 PHP5.0 以 后 的 版 本 中 , 使 用 clone 关键 字 实 现 对 对 象 的 克隆 , 该 关键 字 的 语法 格式 


S$obj_new = clone $obj_old; 
初学 者 可 能 会 问 ， 直 接 用 等 号 不 就 可 以 将 当前 对 象 赋 给 一 个 其 他 对 象 么 ， 为 什么 还 要 


| 用 clone 关键 字 呢 ? 这 主要 是 因为 , 在 PHP5.0 中 对 象 被 存储 于 独立 的 结构 Object Store 中 ， 
| 而 不 像 其 他 一 般 变量 存储 于 Zval 中 ， 在 Zval 中 仅 存储 对 象 地址 的 引用 ， 而 不 是 内 容 ， 当 
| 赋值 一 个 变量 或 者 将 一 个 变量 传递 给 一 个 函数 时 ， 就 不 再 复制 数据 了 ， 所 以 对 新 变量 的 更 
| 改 不 会 导致 原 变量 内 容 的 更 改 ， 而 采用 Object Store 存储 对 象 时 ， 使 用 等 号 产生 一 个 新 对 
| 象 后 ， 对 新 对 象 的 更 改 会 导致 原 对 象 的 更 改 ， 而 使 用 clone 关键 字 所 克隆 出 的 对 象 ， 新 对 
| 象 的 更 改 并 不 会 导致 原 对 象 的 更 改 。 


| 指点 迷津: 


使 用 clone 关键 字 克 隆 一 个 对 象 ， 就 如 同 克隆 一 个 人 ， 打 一 下 新 克隆 出 的 人 ， 被 克隆 


| 的 人 并 不 会 感到 疼痛 ， 其 中 的 道理 是 一 样 的 


实例 223 使 用 _set() 方 法 为 类 中 未 经 定义 的 属性 赋值 


( 实例 位 置 : 配套 资源 \SL\12\223 ) 


“实例 说 明 


通过 本 实例 主要 讲解 如 何 使 用 PHP 中 的 _ set0 方 法 存 取 类 中 未 声明 的 属性 。 运行 本 实 
例 ， 如 图 12.25 所 示 ， 在 页 面 中 以 表格 的 形式 列 出 各 图 书 的 详细 信息 ， 其 中 图 书 的 “备注 ” 
属性 是 使 用 _ set() 方 法 所 赋 的 值 。 


《PHP 从 基础 到 *+》 650 小 张 、 小 潘 、 小 王 %8 备注 
《PHP 函 数 **》 800 小 潘 、 小 王 0 备注 
《PHP 范 例 **》 700 小 地. 小 恒 85 备注 
《PHP 实 战 **》 750 小 郭 、 小 刘 75 备注 


图 12.25 图 书信 息 列表 
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实现 过 程 
具体 步骤 如 下 : | 
(1) 定义 图 书 类 Book， 在 类 中 定义 图 书 的 名 称 、 页 码 、 作 者 和 价格 等 属性 ， 并 分 别 | 

定义 这 些 属性 的 setXxx0 和 getXxx0 方 法 ， 然 后 在 类 中 声明 _set0 方 法 ， 使 用 该 方法 为 类 | 

中 未 声明 的 属性 赋 初 值 。 实 现 该 过 程 的 代码 如 下 : 


S$this->other = $value; 


class Book // 定 义 图 书 类 | 
: private $name: // 书 名 
private $page: // 页 码 | 
private $writer; /作者 | 
private $price; /价格 | 
private $other; // 其 他 信息 | 
public function setName ($name) // 设 置 书 名 | 
: S$this->name = $name; 
a function getName 0 // 获 得 书 名 
return $this->name; 
人 function setPage ($page) /设置 页 码 
S$this->page = $page; 
a function getPage 0 // 获 得 页 码 | 
Tetum $this->page; | 
2 function setWriter ($writer) /设置 作者 
Sthis->writer = $writer; 
2 function getWriter () // 获 得 作者 

: return $this->writer; 
人 function setPrice ($price) // 设 置 价格 

| S$this->price = $price; 
i function getPrice 0 // 获 得 价格 
return $this->price: 
i function _set ($name, $value) 

{ 
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| public function getOther 0 
| { 


a4 
(2) 建立 图 书信 息 二 维 数组 ， 用 于 保存 图 书信 息 ， 代 码 如 下 : 


Tetum $this->other; 


require 'Book.php'; 

SarrayBook = array( 1/ 图书 信息 数组 ， 用 于 模拟 图 书信 息 数 据 表 
array("name'=>'《PHP 从 基础 到 **》', 'page'=>'650', 'writer=>' 小 张 、 小 潘 、 小 王 ','price'=>'58")， 

alray('name'=>'《PHP 函数 **》', 'page'=>'800', "writer=>' 小 潘 、 小 王 ','price'=>'80"), 

array('name'=>'《PHP 实例 **》', page'=>'700', 'writer'=>' 小 李 、 小 懂 ','price'=>'85'), 

array('name'=>'《PHP 实战 **》', 'page'=>"750', "writer=>' 小 郭 、 小 刘 ','price'=>'75') 


); 
(3) 使 用 foreach 语句 通过 循环 输出 图 书信 息 。 在 foreach 循环 体内 部 ， 首 先 对 Book 
类 进行 实例 化 ， 然 后 分 别 调用 类 中 的 setXxx0 方 法 为 类 中 已 声明 的 属性 赋 初 值 ， 同 时 为 类 
中 的 未 声明 的 备注 属性 赋值 ， 最 后 使 用 getXxx0 方 法 打印 出 图 书 的 信息 。 实 现 该 过 程 的 代 
码 如 下 : 
<2php 
Tequire 'db.php'; 
foreach ($arrayBook as $key => $aBook) { 
$book = new Book(); 
$book->setName($aBook[mame']); 
$book->setPage($aBook['page']); 
$book->setWriter($aBook['writer’]): 
$book->setPrice($aBook['price']); 
$book->bz =' 备 注 '; 
> 
<div style="width:100%6: <?php if($key < count($arrayBook)-1){?>border-bottom: 1px solid #0463BD; 
<2php } ?> clearboth:"> 
<div style="width:160px; height:22px: line-height:22px:; text-align:left: float:left:"> 
<?php echo $book->getName0?> 
</div> 
<div style="width: 160px: height:22px: line-height:22px; border-left: 1px solid #0463BD; float:left:"> 
<2php echo $book->getPageO?> 
| </div> 
| <div style="width:160px:; height:22px:; line-height:22px; border-left: 1px solid #0463BD; float:left;"> 
| <2php echo $book->getWiiter0?> 
</div> 
| <div style= "width:160px: height:22px: line-height:22px; border-left: 1px solid #0463BD; float:left;"> 
| <2php echo $book->getPrice0?> 
| </div> 
| <div style= "width:156px: height:22px: line-height22px: border-left: 1px solid#463BD: float:left:"> 
| <?php echo $book->getOther0?> 
| </div> 
| </div> 
| <2php }7> 
| . 354 . 
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技术 要 点 


魔术 方法 _ set0 的 作用 是 存 取 类 中 未 声明 的 属性 ， 该 方法 必须 接收 两 个 参数 ， 分 别 用 | 
来 表示 类 中 未 声明 的 属性 名 和 属性 值 。_set() 方 法 的 语法 格式 如 下 : | 


fonction set($name, $value) 


// 可 以 使 用 $name 和 $value 在 方法 中 存 取 类 中 未 定义 的 属性 名 和 数值 
} 


上 述 _set0 方 法 中 的 参数 Sname 表示 类 中 未 声明 属性 的 名 称 ，Svalue 表示 类 中 未 声明 | 
属性 的 值 。 


实例 224 使 用 _get0 方 法 获取 未 声明 属性 的 名 称 


( 实例 位 置 : 配套 资源 \SL\12\224 ) 


实例 说 明 
本 实例 要 应 用 ”get0 方 法 获得 类 中 未 定义 属性 的 [rm te Bh | 
值 。 运 行 本 实例 ， 如 图 12.26 所 示 ， 页 面 中 打印 的 内 容 = i 


是 通过 调用 荚果 类 的 属性 打印 的 结果 ， 而 弹出 的 提示 对 
话 框 是 因为 没有 在 类 中 定义 $produceArea 属性 而 通过 
_ get( 方 法 弹出 的 。 

现 过 程 


具体 步骤 如 下 : | 

(1) 定义 华 果 类 Apple， 在 该 类 中 分 别 定义 苹果 颜色 、 形 状 和 重量 等 属性 ， 并 使 用 构 | 
造 方法 对 这 些 属性 进行 初始 化 ， 然 后 定义 用 于 获得 苹果 属性 信息 的 getProperty0 方 法 ， 最 | 
后 定义 get0 方 法 用 于 弹出 未 定义 属性 名 称 的 对 话 框 。 实 现 该 过 程 的 代码 如 下 : 


图 12.26 类 中 未 定义 属性 提示 框 


class Apple 

{ 
private $color; /颜色 
private $shape: /形状 
Private $weight; // 重 量 
public function construct ($color, $shape, $weight) /构造 方法 
{ 


S$this->color = $color; 
Sthis->shape = $shape: 
S$this->weight = $weight; 
| 
public function getProperty 0 
{ 
Tetum ' 这 个 苹果 重 '. $this->weight .'， 是 ' . $this->color .'，' . $this->shape . "的! '; 
} 
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public function get ($name) 
| { // 使 用 _get0 方 法 弹出 未 定义 属性 的 提示 
| echo '<script>alert(" 在 类 中 未 定义 属性 ' . $name .…! ");</script>'; 
| } 
mw 
| (2) 使 用 new 关键 字 对 苹果 类 Apple 进行 实例 化 ， 然 后 使 用 实例 化 后 的 对 象 调用 荚 
果 类 中 的 getProperty0 方 法 打印 苹果 的 属性 信息 ， 最 后 使 用 苹果 对 象 调用 类 中 未 定义 的 属 
| 性 。 实 现 该 过 程 的 代码 如 下 : 
| require 'Apple.php'; // 使 用 require 语句 包含 Apple.php 文件 
$apple = new Apple(' 红 色 ', ' 圆 形 ', '0.4kg'); // 使 用 new 关键 字 对 Apple 类 进行 实例 化 
echo $apple->getProperty(); // 调 用 类 中 的 getProperty0 属 性 
| echo $apple->produceArea; 
| 技术 要 点 
魔术 方法 _ get0 用 于 获得 类 中 不 存在 属性 的 名 称 ， 该 方法 必须 带 有 一 个 表示 未 定义 属 
| 性 名 称 的 参数 。_get() 方 法 使 用 格式 如 下 : 
| function _ get($name) 


// 在 方法 内 部 可 以 使 用 $name 的 值 ， 该 值 即 为 未 定义 方法 的 名 称 
} 


实例 225 使 用 _call0 方 法 打印 类 中 未 定义 方法 的 信息 


( 实例 位 置 : 配套 资源 \SL\12W225 ) 


| 实例 说 明 

”通过 本 实例 主要 讲解 _call0 魔 术 方 法 的 使 用 。 运 

| 行 本 实例 ， 如 图 12.27 所 示 ， 将 在 页 面 中 打印 出 图 书 《PH 东风"》 的 价格 是 85 元 
| 的 信息 和 调用 未 定义 方法 的 名 称 。 其 中 图 书 的 信息 是 ent 本 


| 图 书 类 调用 类 中 的 getProperty0 方 法 所 返回 的 结果 , 而 
| 未 定义 getInfo 方法 的 提示 是 通过 类 中 的 _call0 方 法 
| 的 打印 结果 。 

| 实现 过 程 

| 具体 步骤 如 下 

| (1) 定义 图 书 类 Book， 首 先 在 该 类 中 定义 $name 和 S$price 属性 ， 并 使 用 构造 方法 对 
| 这 两 个 参数 进行 实例 化 ， 然 后 定义 getProperty0 方 法 返回 图 书 属性 ， 最 后 定义 call0 方 法 
| 打印 未 定义 方法 的 名 称 。 实 现 该 过 程 的 代码 如 下 : 

| class Book // 图 书 类 


图 12.27 类 中 未 定义 属性 提示 框 


| private $name: // 书 名 
2 356 
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Private $price; /价格 
public function construct ($name, $price) // 构 造 方法 
{ 


$this->name = $name; 
S$this->price = $price; 


i function call ($name, $arguments) //_call0 方 法 

, echo $name . 方法 未 定义 ' 

全 function getProperty | /获得 图 书信 息 的 方法 
return $this->name . ' 的 价格 是 ' . $this->price . ' 元 '; 

} 


} | 
(2) 使 用 new 关键 字 对 Book 类 进行 实例 化 ， 然 后 使 用 实例 化 的 对 象 调用 类 中 的 
getProperty() 方 法 打印 图 书信 息 ， 最 后 使 用 实例 后 的 对 象 调用 类 中 未 定义 的 getmfo() 方 法 。 
实现 该 过 程 的 代码 如 下 : 


require 'Book.php'; // 包 含 Book.php 文件 

$bookName ='《PHP 实例 **》' // 书 名 

$price = "85'; /价格 

$book = new Book($bookName, $price): /对 Book 类 进行 实例 化 

echo $book->getProperty0 . '<br/>"; /打印 图 书 属性 

$book->getInfo($bookName, $price); /调用 类 中 未 定义 的 getInfo0 方 法 
技术 要 点 


魔术 方法 _call0 的 作用 是 在 调用 类 中 一 个 不 存在 或 不 可 见 的 方法 时 将 执行 该 方法 ， | 
_ call( 方 法 必须 接收 两 个 参数 ， 用 来 存放 视图 调用 的 方法 名 及 其 参数 。 该 方法 的 语法 格式 | 
如 下 : | 


function call($name, $arguments) 
{ 


) 


上 述 实例 代码 中 的 参数 Sname 用 于 表示 类 中 未 定义 方法 名 称 ，Sarguments 用 于 表示 未 | 
定义 方法 的 参数 所 组 成 数组 。 | 


实例 226 使 用 toString() 方 法 将 类 的 实例 转化 为 字符 串 


( 实例 位 置 : 配套 资源 \SL\12W226 ) 


实例 说 明 


本 实例 主要 讲解 如 何 通 过 toString0 魔 术 方 法 将 类 实例 的 对 象 转换 为 字符 串 ， 运 行 本 
实例 ， 如 图 12.28 所 示 ， 在 页 面 中 打印 出 圆 的 半径 和 该 半径 对 应 的 圆 面 积 ， 其 中 圆 的 面积 | 
。357 。 LU 
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| 是 直接 打印 圆 类 实例 对 象 的 结果 。 


图 的 半径 是 : 2 


加 的 面积 是 :1257 
| 图 12.28 “打印 圆 的 半径 和 面积 
实现 过 各 


具体 步骤 如 下 : 
| (1) 创建 圆 类 Circle， 在 圆 类 中 定义 圆 半径 私有 属性 Sradius， 并 使 用 构造 方法 对 该 属 
| 性 进行 初始 化 ， 然 后 定义 _toString0 魔 术 方法 ， 使 用 该 方法 返回 圆 的 面积 值 ， 代 码 如 下 : 


class Circle /定义 圆 类 

{ 
private $radius; // 圆 半径 属性 
public function __construct ($radius) // 构 造 方法 
{ 


$this->radius = $radius; 

} 

public function _ toString 0 // 定 义 _toString0 方 法 
retum " 圆 的 面积 是 : " . (string) number format((pi0 * pow($this->radius, 2)), 2); 


} 
} 


| (2) 使 用 require 语句 包含 Circle.php 文件 ， 然 后 设 定 圆 的 半径 为 2， 并 使 用 echo 语 
| 名 输出 圆 的 半径 和 圆 类 实例 的 对 象 ， 代 码 如 下 ; 


require 'Circle.php': // 包 含 CircleArea.php 文件 
S$radius = 2; // 圆 半径 
echo ' 圆 的 半径 是 :'.$radius.'<br/>'; /打印 圆 半 径 的 值 

| echo new Circle($radius); // 打 印 圆 面积 

| 技术 要 点 


魔术 方法 _toStringO 的 作用 是 将 类 实例 的 对 象 转换 为 字符 串 , 该 方法 的 语法 格式 如 下 : 
function _ toStringO{ 
Ietum 字符 串 ; 
上 
| 该 方法 的 返回 值 必须 为 字符 串 类 型 ， 如 果 在 类 中 未 定义 该 方法 ， 当 直接 输出 某 一 个 类 
| 实例 的 对 象 时 ， 将 在 页 面 中 打印 如 下 错误 提示 : 


Catchable fatal error: Object of class Test could not be converted to string in D:\WAppServVwwwANMRA\ 


07\027\tphp on line 3 
| 当 在 类 中 定义 _toString(0 方 法 后 ， 直 接 输 出 类 实例 后 的 对 象 将 在 页 面 中 打印 _toString0 
| 方法 所 返回 的 字符 串 。 
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实例 227 使 用 isset(O 方 法 提示 未 定义 属性 信息 
( 实例 位 置 : 配套 资源 \SL\12\227 ) 
实例 说 明 


运行 本 实例 ， 如 图 12.29 所 示 ， 在 页 面 中 打印 出 未 定义 属性 的 提示 信息 以 及 “小 明 ” | 
年 龄 和 体重 信息 ， 其 中 类 中 未 定义 属性 sex 的 提示 信息 是 通过 魔术 方法 _isset0 打 印 的 。 | 


在 类 中 未 定义 属性 sex 


节 


es 


小 明 的 年 龄 是 ，12 岁 ， 体 重 是 ，45 公 斤 


图 12.29 打印 人 的 属性 信息 

实现 过 程 
具体 步骤 如 下 : | 
(1) 定义 人 类 Person， 在 该 类 中 定义 人 的 名 称 、 年 龄 和 体重 等 属性 ， 并 定义 与 这 些 | 
属性 相对 应 的 setXxx0 方 法 和 getXxx0 方 法 ， 代 码 如 下 : | 


class Person 

。 private $name; // 名 称 
private $age; /年龄 
Private $weight; // 体 重 
public function setName ($name) // 设 置 名 称 
: Sthis->name = $name; 
function getName 0 // 获 得 名 称 
， retum $this->name; 
function setAge (gage) /设置 年 龄 | 
$this->age = $age: 
A function getAge () // 获 得 年 龄 
"| Tetum $this->age; | 

public function setWeight ($weight) // 设 置 体重 

: Sthis->weight = $weight: 
a /获得 体重 
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return $this->weight: 


中 
public function __ isset ($name) // 定 义 _isset0 方 法 


echo ' 在 类 中 未 定义 属性 ' . $name; 


| 2) 使 用 new 关键 字 对 Person 类 进行 实例 化 ， 然 后 分 别 调用 该 类 中 相应 的 setXxx0 
| 方法 为 类 中 的 属性 赋 初 值 ， 并 使 用 函数 isset0 判 断 类 中 未 定义 的 sex 属性 是 否 被 设置 。 实 
| 现 该 过 程 的 代码 如 下 : 


require 'Person.php'; // 包 仿 Person php 文件 
Sperson = new Person(); // 实 例 Person 类 
$person->setName(" 小 明 "); /设置 名 称 
S$person->setAge('12'); // 设 置 年 龄 
S$person->setWeight(45 公斤 ): /设置 体重 
isset($person->sex); // 判 断 是 否 在 类 中 定义 了 sex 属性 
echo '<br/>"; /换行 
echo $person->getName0).' 的 年 龄 是 : .$person->getAge0.' 岁 ， 体 重 是 : '.$person->getWeight() ; 
| // 打 印信 息 
| 技术 要 点 


| 魔术 方法 _isset0 的 作用 是 当 使 用 isset0 函 数 判 断 类 中 未 定义 的 属性 是 否 被 设置 时 所 
| 调用 的 。 该 方法 的 使 用 格式 如 下 : 
| function _ isset ($name) 
{ 
} 
魔术 方法 _isset0 必 须 包 含 一 个 用 于 代表 类 中 未 定义 属性 的 名 称 参数 。 


实例 228 使 用 单 例 模 式 制 作 数 据 库 管 理 类 


( 实例 位 置 : 配套 资源 \SL\12\228 ) 


”实例 说 明 

| 本 实例 主要 讲解 如 何 使 用 单 例 模式 制作 一 个 基于 MySQL 数据 库 的 数据 库 管 理 类 。 运 
| 行 本 实例 ， 如 图 12.30 所 示 ， 首 先 在 用 户 登 录 文 本 框 中 输入 用 户 名 和 密码 ， 然 后 单 击 表单 
| 中 的 “登录 ”按钮 ， 如 果 用 户 名 和 密码 经 后 台 代码 验证 正确 则 当前 页 面 将 跳 转 到 登录 成 功 
| 信息 提示 页 面 ， 如 果 错 误 则 在 页 面 打印 错误 提示 ， 在 上 述 过 程 中 ， 对 数据 库 管 理 模块 在 技 
| 术 上 采用 PDO 技术 ， 设 计 上 是 采用 单 例 模式 进行 编码 的 。 
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ETE | 


{0) 1999.3010 明日 [I 新闻 开 


图 12.30 ”用户 登录 表单 

实现 过 程 

具体 步骤 如 下 : | 

(1) 建立 数据 库 连 接 类 Db， 在 类 中 定义 用 于 保存 当前 类 实例 的 静态 成 员 变量 | 
$instance， 并 定义 静态 方法 getInstace()。 在 该 方法 内 部 将 当前 类 实例 的 对 象 赋 给 静态 成 员 | 
变量 $instance 并 返回 ， 然 后 定义 私有 的 构造 方法 和 私有 的 克隆 方法 ， 这 样 就 构建 了 单 例 模 | 
式 的 基本 框架 ， 接 下 来 创建 getConnId0 方 法 。 该 方法 用 于 返回 使 用 PDO 技术 连接 数据 库 | 
后 的 句柄 , 然后 创建 数据 库 查 询 方法 query0 实 现 对 数据 库 的 查询 操作 。 实 现 该 过 程 的 代码 | 
如 下 : | 


class Db // 数 据 库 类 
. Private static $instance; // 保 存 当 前 类 实例 后 的 对 象 
public static function getInstance 0 // 静 态 方法 ， 返 回 类 实例 
if (null — self:$instance) { // 如 果 未 定义 
self::$instance = new DbO): 
2 self::$instance; 
2 function construct 0 /私有 构造 方法 
fonction clone 0 // 私 有 克隆 方法 
本 function getConnId 0 // 获 得 数据 库 连 接 人 D 的 方法 
{ 


Sconfig = parse_ini file(dirmame( FILE ).'/config.ini); // 解 析 配 置 文件 
$dsn = 'mysql:host=' . $config['host] . ;dbname=' . $config['dbname']; ”// 配 置 数 据 源 名 称 
$pdo = new PDO($dsn., $config['usermame'], $config['password']): // 实 例 PDO 对 象 


$pdo->query('set names ' . $config['charset ]): // 设 置 字符 集 
return $pdo; // 返 回 PDO 对 象 
9 
public function query ($sql) // 查 询 方法 
{ 
S$pdo = $this->getConnIdO: // 获 得 PDO 对 象 
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$sqlType = trim(substr($sql, 0, 6)); // 获 得 查询 语句 类 型 
if($sqlType 一 "pdate' || $sqlType 一 "delete' || $sqlType 一 "insert) { 
| return $pdo->query($sql); // 如 果 是 update、delete 
| 或 insert 语句 则 返回 SQL 语句 执行 结果 
y | } elseif ($sqlType 一 'select) { // 如 果 是 select 语句 
鲜 | | StmpArray = amray0: /定义 二 维 数组 
| Sresults = $pdo->query($sqD); /执行 select 语句 
foreach ($results as $result) { // 将 结果 保存 到 二 维 数组 中 
| array_push($tmpArray, $result); 
return $tmpArray; // 返 回 结果 
} else { 
Tetum null: // 不 是 update、delete、insert 或 select 语句 ， 则 返回 pull 
b 


} 
} 
| (2) 建立 用 户 登 录 表 单 ， 其 实现 过 程 请 详 见 本 书 附带 源码 配套 资源 。 当 用 户 在 表单 
| 中 录入 完成 用 户 名 和 密码 ， 单 击 “ 提 交 ” 按 钮 后 将 通过 如 下 代码 验证 用 户 的 登录 信息 是 否 
| 正确 。 
| iflisset($_POST['username']) && trim($_ POST['"username'])!=") 


require_once 'Db.php': 
$username = trim($_POST['username']); 
$password = trim(md5($_POST['password'])); 
$db = Db::getInstance(); 
| $arrayUser = $db->query("select id from tb_user where username="".$username." and password 
,=".$password."™"); 
| if(count($arrayUser)>0){ 
$_SESSION['loginUsername'] = $usemame: 
echo '<script>window.location.href="success.php";</script>"; 
}else { 
| echo '<div style="width:300px; height:30px: line-height:30px; border:1px solid #E59B04; 
| background-color: 三 CF2E0: color: 考 F0000:"> 用 户 名 或 密码 输入 有 误 </div>': 
| } 
b 


| 上 述 代 码 首 先 判 断 用 户 是 否 提 交 了 表单 , 如 果 是 则 通过 Db 类 的 getmstance() 方 法 获得 
| 类 的 实例 ,并 通过 该 对 象 调用 类 中 的 query0 方 法 执行 查询 ,根据 查询 结果 的 记录 数 来 判断 
| 用 户 输入 的 用 户 名 和 密码 是 否 正 确 ， 如 果 记 录 数 大 于 1 则 说 明 用 户 登录 信息 有 效 。 

| 技术 要 点 

| 单 例 模式 是 指 在 程序 应 用 范围 内 只 对 指定 的 类 创建 一 个 实例 ， 也 就 是 说 该 模式 包含 的 
| 对 象 只 有 一 个 ， 就 是 单 例 本 身 。PHP 使 用 单 例 模式 所 设计 的 类 通常 应 满足 如 下 要 求 : 
”加 单 例 模式 的 类 通常 拥有 一 个 私有 的 构造 方法 和 私有 的 克隆 方法 ,这 样 可 以 确保 用 

户 无 法 通过 创建 对 象 或 者 克隆 的 方式 对 其 进行 实例 化 。 
回 “ 单 例 模式 的 类 包含 一 个 萝 态 的 用 于 保存 当前 类 实例 的 成 员 变量 以 及 一 个 静态 方 

| 法 ， 该 静态 方法 负责 对 其 本 身 进行 实例 化 ， 然 后 将 实例 化 后 的 对 象 保存 到 类 中 所 
| *。362 。 
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声明 的 静态 变量 中 ， 从 而 确保 一 个 对 象 被 创建 。 
PHP 的 单 例 模式 的 基本 形式 如 下 : 


class Singleton 
% private static $instance; /保存 当前 类 实例 后 的 对 象 
public static function getInstance 0 /静态 方法 ， 返 回 类 实例 
if (null 一 self:$instance) { /如 果 未 定义 
self::$instance = new Db(); 
人 self::$instance; // 返 回 当前 对 象 
a function construct 0 // 私 有 构造 方法 
Do function_ clone 0 // 私 有 克隆 方法 
/的 其 他 广 法 
上 得 关 的 对 和 


S$singleton = Singleton::getInstance():; | 
通过 上 述 代码 可 知 ， 在 类 外 部 通过 类 名 直接 调用 类 中 的 用 于 返回 当前 类 实例 的 静态 方 | 
法 即 可 获得 当前 类 实例 。 | 


实例 229 使 用 策略 模式 打印 客户 端 浏览 器 类 型 


( 实例 位 置 : 配套 资源 \SL\12\229 ) 


例 说 明 


本 实例 主要 讲解 在 PHP 面向 对 象 编 程 中 策略 模式 的 应 用 方法 。 运 行 本 实例 ， 分 别 如 
图 12.31 和 图 12.32 所 示 ， 其 中 图 12.31 是 在 下 下 运行 的 结果 ， 图 12.32 为 在 Firefox 浏览 | 
器 下 运行 的 结果 ， 从 运行 结果 可 知 ， 本 实例 会 根据 不 同 浏览 器 的 类 型 在 页 面 中 打印 相应 浏 | 
览 器 的 名 称 。 | 
人 http: //192. 168. 1. 59/mr/07/3457 172 E| ll 
文件 四 编辑 时) 查看 W) 收 寞 Q) 工具 I) 帮助 > 溃 文件 丰 ) 编 各 人 E) 要 者 (V) 历史 人 G) 书签 () -| 
天 十 @) 图 hp /92 tt9_ 15/nr'0T/345/ 可 因 区 到 | 证 二 可 EC Gy 
刁 当前 浏览 器 是 Firefor 


当前 浏览 器 是 下 


到 
BE 厂矿 厂 © 可 站点 四 [E33 


图 12.31 打印 浏览 器 的 类 型 为 正 图 12.32 打印 浏览 器 的 类 型 是 Firefox 


实现 过 程 


有 具体 步骤 如 下 : | 

(1) 定义 抽象 的 Browser 类 ， 并 在 该 类 中 声明 抽象 方法 getType()， 然 后 定义 子 类 Ie | 

和 Fox， 使 这 两 个 类 分 别 继 承 基 类 Browser， 然 后 在 类 体内 完成 对 getType0 类 的 定义 ， 代 | 
.363 。 
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| 码 如 下 : 
| abstract class Browser // 定 义 抽象 类 Browser 
下 
abstract public function getType O; 
lL 
class Je extends Browser /定义 正 类 
{ 
public function getIype 0 // 获 得 类 型 方法 
{ 
return TE'; 
} 
) 
class Fox extends Browser /定义 Fox 类 
public function getType 0 // 获 得 类 型 方法 
Ietum 'Firefox'; 
} 
} 


| (2) 使 用 header0 函 数 设 置 页 面 编码 ， 并 使 用 require 语句 包含 Browserphp 文件 ， 然 
| 后 定义 getBrowserType0 方 法 获得 浏览 器 类 型 ， 代 码 如 下 : 


header('content-type:text/html: charset=utf-8"): // 定 义 页 面 编码 
require 'Browser.php'; // 包 仿 Browser.php 文件 
function getBrowserType 0 // 定 义 获得 浏览 器 类 型 的 方法 
{ 
寺 (strstr($_SERVER['HTTP_USER_AGENT'], "IE")) { 。// 判 断 是 否 为 正 浏览 器 
$b = new Ie0: /实例 下 类 
} else{ 
$b = new Fox(); // 实 例 Fox 类 
} 
return $b->getTypeO; // 返 回 浏览 器 类 型 
| } 
| echo ' 当 前 浏览 器 是 '. getBrowserType0: /执行 getBrowserType0 方 法 


技术 要 点 
| 策略 模式 是 指 程序 中 涉及 决策 控制 的 一 种 模式 ， 它 通常 定义 一 个 抽象 基 类 ， 然 后 根据 
| 情况 的 不 同 创建 不 同 的 子 类 ， 其 中 一 个 简单 的 策略 模式 框架 如 下 : 


| abstract class Strategy // 定 义 抽象 的 基 类 

: abstract public function fun 0: // 定 义 抽象 方法 fhn0 

ee Childl extends Strategy // 定 义 子 类 Child1， 使 其 继承 基 类 Strategy 
public function fun 0 // 实 现 fun0 方 法 的 功能 

; //Child1 中 fun0 方 法 所 实现 的 功能 
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} 
class Child2 extends Strategy /定义 子 类 Child2， 使 其 继承 基 类 Strategy 
下 

public function fun 0 /实现 fun0 方 法 的 功能 

//Child2 中 fun0 方 法 所 实现 的 功能 

3 
} 
这 条 件 1 一 tmue){ /如 果 条 件 1 为 真 

$obj =new Child10; // 生 成 子 类 Childl 的 实例 对 象 
}else { 

S$obj = new Child20: // 生 成 子 类 Child2 的 实例 对 象 
} 
$obj->fun(); 


上 述 示 例 代码 中 首先 定义 抽象 基 类 Strategy， 并 在 类 中 定义 抽象 方法 fhn0， 然 后 分 别 
定义 类 Childl 和 Child2, 使 这 两 个 类 分 别 继承 基 类 Strategy, 在 这 两 个 子 类 的 内 部 实现 fun() | 
的 功能 ， 完 成 以 上 类 的 定义 后 ， 就 可 以 根据 不 同 的 条 件 对 不 同 的 子 类 进行 实例 化 。 | 


实例 230 使 用 工厂 模式 设置 用 户 访问 权限 


( 实例 位 置 : 配套 资源 \SL\12W230 ) 


实例 说 明 | 

本 实例 主要 讲解 如 何 使 用 工厂 模式 对 用 户 权限 进行 管理 。 运 行 本 实例 ， 如 图 1233 所 | 
示 ， 在 页 面 中 将 打印 出 不 同 用 户 的 类 型 及 各 项 操作 的 访问 权限 。 制 作 本 实例 时 ， 首 先 创建 
抽象 的 用 户 权限 类 ， 然 后 分 别 定义 浏览 、 添 加 、 更 改 和 删除 等 子 类 ， 使 之 继承 基 类 用 户 权 | 
限 类 ， 然 后 根据 不 同 用 户 的 权限 ， 重 写 用 户 权限 类 中 的 方法 ， 最 后 创建 用 户 权限 工厂 来 根 | 
据 不 同 用 户 类 别 来 返回 相应 的 对 象 。 | 


图 12.33 电子 相册 用 户 权限 列表 
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具体 步骤 如 下 : 

| (1) 定义 用 户 权 限 基 类 UserPermission， 然 后 在 该 基 类 中 定义 select0、add0、edit0 和 
| delete() 等 方法 , 然后 分 别 定义 子 类 GuestPermission、MemberPermission 和 AdminPermission， 
并 使 这 些 类 分 别 继承 基 类 UserPermission， 同 时 根据 不 同类 的 功能 对 基 类 中 的 方法 进行 重 
| 写 ， 最 后 定义 用 户 权限 工厂 UserPermissionFactory 来 根据 不 同 用 户 的 类 别 对 相应 的 子 类 进 
| 行 实例 化 并 返回 。 实 现 该 过 程 的 代码 如 下 : 


abstract class UserPermission // 定 义 抽象 的 用 户 权限 类 
public function select 0 // 定 义 查 询 方法 
: retum true; 
2 function add () // 定 义 添加 方法 
, return false; 
a function edit 0 // 定 义 编辑 方法 
: return false; 
a function delete 0 // 定 义 删 除 方法 
! Tetum false; 
} 
Le GuestPermission extends UserPermission // 定 义 浏览 者 权限 类 
MemberPermission extends UserPermission 。 /定义 会 员 权限 类 
public function add 0 // 重 写 添加 方法 
| > TIetum true; 
| } 
a AdminPermission extends UserPermission // 定 义 管理 员 权 限 类 
、 public function add | // 重 写 添加 方法 
| return true; 
es function edit 0 // 重 写 编辑 方法 
ee 
ee function delete 0 // 重 写 删除 方法 
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{ 
Teturm true; 
} | 
class UserPermissionFactory // 用 户 权限 工厂 | 
{ | J 
public static ftnction getUser ($userType) // 获 得 用 户 权限 方法 | 
switch (SuserType) { | 
case 'GUEST : | 
Tetum new GuestPermission(): // 返 回 普通 浏览 者 权限 对 象 | 
break; | 
case MEMBER:: | 
Tetum new MemberPermission(); // 返 回 会 员 权 限 对 象 
break: 
case 'ADMIN': 
Tetum new AdminPermission(): // 返 回 管理 员 权限 对 象 
break: 
b 
} 
} 


(2) 定义 二 维 数组 Susers， 使 用 该 数组 保存 用 户 名 称 及 权限 类 别 ， 代 码 如 下 : 


$users = array( 
0=>array(name'=>' 大 麦 , 'type' => 'GUEST'), 
1=>array('name'=>'SOFT,', 'type’ => 'MEMBER'), 
2=>array(name'=>' 春 泉 ', 'type' => 'GUEST'), 
3=>array(name'=>' 爹 星 ', 'type' => 'GUEST'), 
4=>array('name'=>'360', 'type' => "MEMBER'), 
5=>aray(name=>MR' type => 'ADMIN") 
jE 
(3) 使 用 require 语句 包含 UserPermissionFactoryphp 及 db php 文件 ， 然 后 使 用 foreach 
循环 语句 遍历 用 户 数组 ， 并 根据 用 户 类 别 通过 用 户 权 限 工 厂 生成 相应 的 用 户 权 限 对 象 ， 最 
后 打印 用 户 权限 信息 。 实 现 该 过 程 的 代码 如 下 : 


<2php 
require 'UserPermissionFactory.php': // 包 含 用 户 权限 工厂 所 在 文件 | 
require 'db.php'; // 包 含 用 户 信 息 数 组 所 在 文件 | 
foreach ($users as $user){ /人 遍历 用 户 权 限 数组 | 
$userPermission = UserPermissionFactory::getUser($user['type']); 。// 获 得 用 户 权 限 对 象 | 
?> | 
<!-- ”以 下 代码 用 于 打印 用 户 权限 信息 ”--> | 
<tr> | 


<td style= "width:80px: height:22px; border: 1px solid #E0056F;"><?=$user['name']?></td> | 
<td style="width:80px: height:22px: border lpx solid #E0056F:;"><?=str_replace(ADMIN', "管理 | 
员 ', str_replace(MEMBER', ' 会 员 ', str replace(CGUEST'' 访 客 ', $user[type])))?></td> | 
<td style= "width:80px; height:22px: border:1px solid #E0056F;"><?=$userPermission->select()?' | 
是 ":" 否 ?></td> | 
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EC 
eh 
| <td style= "width:80px: height:22px; border:1px solid #E0056F;"><?=S$userPermission->add0?' 是 
| “ 否 9></td> 

| <td style="width:80px; height:22px: border:1px solid #E0056F;"><?=$userPermission->edit()?' 是 
| “ 鲁 ><td> 

仿 F | <td style="width:80px; height:22px: border:1px solid #E0056F;"><?=$userPermission->delete()?' 
下 | 是 : 否 ?></td> 


| </tr> 
<pbp 

} 

| ?> 

| 技术 要 点 

| 工厂 模式 是 指 创建 一 个 类 似 于 工厂 的 类 ， 通 过 对 类 中 成 员 方法 的 调用 返回 不 同类 型 的 

| 对 象 。 使 用 工厂 模式 时 ， 首 先 创建 一 个 基 类 ， 然 后 根据 对 象 类 型 的 不 同 来 创建 不 同 的 扩展 

| 类， 最 后 定义 工厂 类 ， 根 据 不 同 的 条 件 来 返回 相应 的 对 象 。 工 厂 模式 的 实例 代码 如 下 ; 


abstract class Father /定义 基 类 
{ 
} 
class Childl extends Father /定义 子 类 1 
{ 
} 
class Child2 extends Father // 定 义 子 类 2 
{ 
} 
class Factory // 定 义工 厂 类 
{ 
public static function create ($condition) // 创 建 对 象 
计 ($condition 一 ' 条 件 1") { 
return new Child1(): 
} elseif ($condition 一 ' 条 件 2") { 
Tetum new Child2():; 


} 
} 
} 
| 上 述 示 例 代码 中 ， 首 先 定义 抽象 基 类 Father， 然 后 定义 子 类 Childl 和 Child2， 使 之 分 别 
| 继承 基 类 Father， 在 实际 应 用 中 还 应 该 重 写 或 定义 子 类 Childl 和 Child2 中 的 方法 ， 最 后 定 
| 义工 厂 类 Factory, 并 在 该 类 中 定义 静态 的 create0 方 法 来 根据 不 同 的 条 件 返 回 相应 的 对 象 。 


| 指点 迷津 
抽象 基 类 也 可 以 使 用 接口 来 代替 。 
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术 章 读者 可 以 学 到 如 下 实例 : 

WI 实例 231 连接 MySQL 数据 库 

WI 实例 232 ”连接 MS SQL Server 数据 库 

WI 实例 233 连接 Oracle 数据 库 

WI 实例 234 通过 PDO 向 数据 库 中 添加 数据 
WI 实例 235 通过 PDO 浏览 数据 库 中 的 数据 
WI 实例 236 通过 PDO 更 新 数据 库 中 的 数据 
WI 实例 237 浏览 客户 留言 

MH 实例 238 明日 书店 会 员 注册 

WI 实例 239 添加 留言 信息 

WI 实例 240 查询 留言 


在 pe 
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实例 231 连接 MySQL 数据 库 


( 实例 位 置 : 配套 资源 \SL\13W231) 


ey 实例 说 明 


在 学 习 通 过 PDO 连接 MySQL 数据 库 之 
| 前 ,大 家 先 在 phpMyAdmin 下 创建 一 个 MySQL 
| 数据 库 db_database13， 并 且 在 db_databasel3 
| 数据 库 中 创建 数据 表 tb_pdo， 然 后 定义 数据 库 
| 连接 的 参数 ， 最 后 ， 通 过 PDO 构造 函数 创建 人 
| 连接 。 运 行 效果 如 图 13.1 所 示 。 国生 全 WO 于 可 队 
| 实现 过 程 
| 具体 步骤 如 下 : 
| (1) 创建 脚本 文件 index.php。 编写 连接 MySQL 数据 库 的 连接 参数 , 其 中 包括 $dbms、 
| $dbName、 Suser、S$Spwd 和 $host。 
| (2) 实例 化 PDO 对 象 ， 输 出 连接 成 功 的 提示 并 利用 try...catch... 语 句 捕获 异常 。 其 


| 代码 如 下 : 
| <2php 
header("Content-Type:text/html:charset=utf-8"): // 设 置 页 面 的 编码 格式 
$dbms="mysql'; 1/ 数据库 类 型 
$dbName='db_database13' /使 用 的 数据 库 名 称 
$user='root'; /使 用 的 数据 库 用 户 名 
S$pwd="111'; 1/ 使 用 的 数据 库 密码 
$host='localhost': // 使 用 的 主机 名 称 
$dsn="$dbms:host=$host;:dbname=$dbName"; 
try{ /捕获 异常 
Spdo=new PDO($dsn,$user$pwd); /实例 化 对 象 
echo "PDO 连接 MySQL 成 功 "; 
} catch (Exception $e) { 
echo $e->getMessage()."<br>"; 
} 
| ?> 
”技术 要 点 
| 在 PDO 中 , 要 建立 与 数据 库 的 连接 需要 实例 化 PDO 的 构造 函数 , PDO 构造 函数 的 语 


| 法 如 下 : 
| __construct(string $dsn[.string $usermame[.string $password[,array $driver_options]]]) 


参数 说 明 : 
dsn: 数据 源 名 ,包括 主机 名 端口 号 和 数据 库 名 称 。 
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usemame: 连接 数据 库 的 用 户 名 。 
password: 连接 数据 库 的 密码 。 
回 driver options: 连接 数据 库 的 其 他 选项 。 


实例 232 连接 MS SQL Server 数据 库 


( 实例 位 置 : 配套 资源 \SL\13\232 ) 


实例 说 明 
PDO 这 种 抽 象 层 的 人 概念 可 以 实现 与 主 流 De 放 Win. 
的 数据 库 使 用 同一 接口 进行 连接 。 连 接 的 方 SS < 
| 室 闪 。 才 htpy/1921681194/S- 人 向- 


法 是 定义 指定 的 PDO 参数 , 然后 利用 同一 方 
法 操作 即 可 。 本 实例 通过 PDO 连接 MS SQL 
Server 数据 库 ， 其 运行 结果 如 图 13.2 所 示 。 


实现 过 程 | 
本 实例 应 用 PDO 连接 MS SQL Server 数据 库 ， 其 操作 非常 简单 ， 只 需 更 改 PDO 参数 
$dbms 为 mssql，$user 为 sa，$pwd 为 “”( 空 ) 即 可 。 然 后 使 用 与 连接 MySQL 数据 库 相 | 
同 的 方法 实现 连接 SQL Server 数据 库 。 其 代码 如 下 : | 


| 连接 NS SQL Server 成 功 
le Internet | 保护 模式 : 禁用 


给 ” 拆 105% > 


图 13.2 ”连接 MS SQL Server 数据 库 


<2php 
header("Content-Type:text/html:charset=utf-8"): // 设 置 页面 的 编码 风格 
$host=PC-201006101638'; /设置 主机 名 称 
$user=!'sa'; /设置 用 户 名 
$pwd="; /设置 密码 
SdbName='db_databasel3'; /设置 所 要 连接 的 数据 库 
$dbms="mssql'; 
$dsn="mssql:host=$host:dbname=$dbName":; 
ty{ // 利 用 try.…catch 捕捉 异常 并 实现 连接 


$pdo = new PDO($dsn.$user$pwd); 
echo "连接 SQL SERVER 成 功 "; 

} catch (Exception $e) { 
die("ERROR!".$e->getMessage()."<br>"); 


} 
?> 
技术 要 点 


(1) 如 何 测试 你 的 PHP 是 否 支持 MS SQL Server 数据 库 ， 编 写 一 个 phpinfo php 文件 ， 
文件 内 容 如 : <?php echo phpinfo(); ?>, 运 行 该 文件 ， 即 可 查看 出 PHP 是 否 支 持 MS SQL | 
Server 数据 库 。 | 

(2) 在 phpini 文件 中 有 关 mssql 的 配置 已 经 修改 完成 后 ，PHP 仍 不 支持 mssql 的 解 | 
决 方案 : 将 PHP 安装 目录 下 的 ntwdblib.dll 文件 复制 到 本 机 系统 盘 的 WINDOWS\system32 | 
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| 文件 夹 下 ， 然 后 重新 启动 Apache 服务 器 。 


实例 233 连接 Oracle 数据 库 


( 实例 位 置 : 配套 资源 \SL\13\233 ) 


| 实例 说 明 


这 里 我 们 连接 Oracle 数据 库 服务 器 , 数据 库 名 称 是 192.168.1.59:1521/oralcles, 数据 库 


| 服务 器 的 用 户 名 是 system， 密 码 为 mrsoft。 其 运行 结果 如 图 13.3 所 示 。 


| 实现 过 程 


笑 http://192.168.1.194/SL/13/233/ - Win.. 


OO- [他 hupynez21.. hal4[x|[P Be 


窗 收 襄 夫 。 | 入 httpy/192.168.1.194/S… 芥 ~ 


Oracle 数 据 库 连接 成 功 
图 Internet | 保护 模式 :禁用 给 >” 所 105% > 


图 13.3 ”连接 Oracle 数据 库 
首先 ， 定 义 数 据 库 连接 的 参数 。 然 后 ， 实 例 化 PDO 构造 函数 。 最 后 ， 通 过 try catch 
语句 判断 数据 库 是 否 连接 成 功 。 其 代码 如 下 : 


<2php 
$dbms='oci': /数据 库 类 型 ， 对 于 开发 者 来 说 ， 使 用 不 同 的 数据 库 ， 只 要 改 这 个 ， 不 用 记 住 那么 
多 的 函数 


$dbName="'192.168.1.59:1521/oralcles'; // 使 用 的 数据 库 
$user='system'; /数据库 连接 用 户 名 
$pass='mrsoft'; // 对 应 的 密码 
="$dbms:dbname=$dbName" 
ty{ 
$pdo 二 new PDO($dsn, $user, $pass); // 初 始 化 一 个 PDO 对 象 ， 就 是 创建 了 数据 库 连 接 对 象 $pdo 
echo "连接 成 功 <br/>"; 
S$pdo = null; 
} catch (PDOException $e) { 
die ("Error!: " . $e->getMessage() . "<br/>"); 
} 
?> 
技术 要 点 


通过 PDO 连接 Oracle 数据 库 ， 首 先 要 在 本 机 上 安装 Oracle 数据 库 的 客户 端 。 然 后 ， 
去 掉 php.ini 文件 中 extension=php_pdo.dll 和 extension=php_pdo_oci.dll 前 面 的 分 号 ， 加 载 
PDO 模块 .最 后 ,将 Oracle 客户 端的 oraociei10.dll、oci.dll 和 orannzsbb10.dll 复制 到 Apache 
的 bin 文件 夹 下 。 
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实例 234 通过 PDO 向 数据 库 中 添加 数据 


( 实例 位 置 : 配套 资源 \SL\13\234) 


实例 说 明 


PDO 数据 库 抽象 层 的 主要 特点 是 为 不 同 的 数 
据 库 提供 统一 的 接口 , 使 用 户 在 后 期 维护 或 数据 库 
变更 时 减少 麻烦 。 本 实例 通过 PDO 向 已 经 创建 好 
的 数据 库 中 添加 数据 ,其 运行 效果 如 图 13.4 所 示 。 


己 口 口 插入 数据 


区 寻 [可 | 插入 数据 成 功 ， 影 响 条 数 为 1 


由、 寸 得 
现 过 程 图 13.4 通过 PDO 向 数据 库 中 添加 数据 
具体 步骤 如 下 : 


(1) 创建 脚本 文件 index.php， 在 此 脚本 文件 中 编写 表单 ， 其 中 包括 文本 框 、 Wi | 
提交 按钮 和 重 置 按钮 。 
(2) 当 单 击 “ 确 定 ” 按 钮 时 ， 利 用 $_POST 全 局 数组 获取 文本 框 和 密码 框 的 信息 ， 并 
将 其 做 为 SQL 语句 的 参数 。SQL 语句 代码 如 下 : 
$sql="insert into tb_pdo values(",'$_POST[text]','$_POST[pwd]',nowO)"; 


(3) 定义 PDO 抽象 层 的 参数 ， 其 中 包括 $dbms、S$user、$pwd、$host 等 ， 拼 接 $dsn。 | 
(4) 实例 化 PDO 对 象 ， 利 用 对 象 句柄 调用 exec0 函 数 向 数据 库 中 插入 数据 信息 ， 并 
显示 插入 数据 的 条 数 。 其 核心 代码 如 下 : 


<2php 
header("Content-Type:text/html:charset=utf-8"): // 设 置 编 码 格式 
$dbms='mysql'; // 定 义 数据 库 类 型 
$dbName='db database13' /设置 连接 数据 库 
$user=root': // 数 据 库 用 户 名 
S$pwd="111'; /数据 库 密码 
$host='localhost': /服务 器 
$dsn="$dbms:host=$host:dbname=$dbName'"': 
?> 
<?php 
ifisset($_POST[sub])){ // 判 断 是 否 提 交 
if($_POST['text]—""&&$ POST['pwd]—""){ /判断 用 户 名 和 密码 是 否 为 空 
echo "文本 框 内 容 不 能 为 空 "; 
}else{ 
try{ 
S$pdo=new PDO($dsn, $user,$pwd); // 实 例 化 对 象 | 
$sql="insert into tb pdo (usemame,userpwd,date) values(".$_ POST['text].",".$_POST | 
['pwad'].",".date("Y-m-d").")": // 定 义 添加 语句 | 
S$result-$pdo->exec($sqD:; /执行 添加 语句 
echo "插入 数据 成 功 ， 影 响 条 数 为 "Sresult; 
} catch (Exception $e) { 


ey 
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echo "ERROR!!".$e->getMessage0."<br>"。 // 返 回 错误 信息 


本 实例 通过 PDO 中 的 exec0 方 法 向 数据 库 中 添加 数据 。exec0 方 法 返回 执行 后 受 影响 


| 的 行 数 ， 其 语法 如 下 : 


int PDO::exec ( string statement ) 


参数 statement 是 要 执行 的 SQL 语句 。 该 方法 返回 执行 查询 时 受 影 响 的 行 数 ， 通 常用 


| 于 INSERT、DELETE 和 UPDATE 语句 中 。 


| 实例 说 明 


实例 235 通过 PDO 浏览 数据 库 中 的 数据 


( 实例 位 置 : 配套 资源 \SL\13W235 ) 


利用 PDO 抽象 层 显示 数据 需要 使 用 


| ID | 用 户 名 称 用 户 密码 操作 时 间 

| 函数 query0, 此 函数 与 普通 的 操作 数据 库 1 mr mrsoft 2010-11-24 
| 函数 并 无 区 别 ， 只 不 过 在 PDO 中 此 函数 2 La i me 
| 和 3 ym 066066 2010-11-24 
| 只 用 于 数据 的 查询 ， 而 插入 、 修 改 和 更 新 4 pth 123456 2010-11-24 
| 的 方法 需要 使 用 exee0 函 数 来 实现 。 本 实 图 13.5 通过 PDO 浏览 数据 库 中 的 数据 


| 例 的 运行 效果 如 图 13.5 所 示 。 


| 实现 过 程 


的 相关 参数 ， 拼 接 dsn 参数 ， 利 用 对 象 句 柄 $pdo 调用 PDO 抽象 层 的 query0 方 法 并 返回 结 


首先 ， 创 建 脚本 文件 mdex.php， 编 写 表格 ， 设 置 页 面 的 编码 。 其 次 ， 定 义 PDO 所 需 


果 集 。 最 后 ， 将 结果 集 通过 foreach0 语 句 循环 输出 到 表格 中 。 其 代码 如 下 : 


<?php 
header("Content-Type:text/html:charset=utf-8"):; // 定 义 页 面 编 码 风 格 
$dbms="mysql'; // 定 义 PDO 的 相关 参数 
$dbName='db_database13'; 
$user='root'; 
Spwd="111'; 
$host='localhost'; 
$dsn="$dbms:host=$host:dbname=$dbName"; 
pe 
<table> // 表 格 输出 数据 内 容 
<tr> 
<td class="one">ID</td> 
<td class="one"> 用 户 名 称 </td> 
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<td class="one"> 用 户 密码 </td> 
<td class="one"> 操 作 时 间 </td> 
</tr> 
<?php 
ty{ // 利 用 try.….catch... 语 句 捕获 异常 
$pdo=new PDO($dsn, $user, $pwd); 
$sql="select * from tb_pdo"; 
$result=$pdo->query($sq]l); 
foreach($result as $key=>$value){ 
i 
<tr> 
<td><?php echo $value[0]:?></td> /循环 输出 数据 并 定义 到 表格 中 
<td><?php echo $value[1]:?></td> 
<td><?php echo $value[2]:?></td> 
<td><?php echo $value[3];?></td> 
</tr> 
<?php 
} 
} catch (Exception $e) { 
echo "ERROR!!".$e->getMessageO."<br>"; 


技术 要 点 
query() 方 法 通常 用 于 返回 执行 查询 后 的 结果 集 。 其 语法 如 下 : 
PDOStatement PDO::query ( string statement ) 


参数 statement 是 要 执行 的 SQL 语句 ， 它 返回 的 是 一 个 PDOStatement 对 象 。 


实例 236 通过 PDO 更 新 数据 库 中 的 数据 


( 实例 位 置 : 配套 资源 \SL\13\236 ) 


实例 说 明 


在 利用 MySQL 数据 库 函 数 更 新 数据 时 ， 需 要 将 要 更 改 的 数据 信息 id 拼接 到 地 址 栏 的 | 
参数 中 。 通 过 PDO 更 新 数据 库 中 的 数据 也 不 例外 。 在 本 实例 中 ， 单 击 “ 修 改 ” 超 链接 ， | 
将 指定 的 数据 传递 到 表单 中 ， 在 表单 中 对 数据 进行 更 新 ， 最 后 单 击 “确定 ”按钮 ， 完成 更 | 
新 操作 ， 其 运行 效果 如 图 13.6 和 图 13.7 所 示 。 


Io 用 户 名 称 用 户 密码 捧 作 时 间 修改 

Li nraoft 2010-11-24 在 改 

2 mraoft nrkj 2010-11-24 修改 

3 ym 066066 2010-11-24 修改 

4 pkh 123456 2010-11-24 修改 

B Fansmng ee Po124 确定 
图 13.6 通过 PDO 更 新 数据 库 中 的 数据 图 13.7 更 新 数据 成 功 
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实现 过 程 
首先 ， 创 建 脚本 文件 index.php。 编 写 表 格 ， 设 置 PDO 抽象 层 的 相关 参数 拼接 $dsn 变 
量 。 通 过 PDO 中 的 预 处 理 语句 prepare0 和 execute0 执 行 SQL 查询 语句 ， 并 且 应 用 while 
语句 和 fetch0) 方 法 完成 数据 的 循环 输出 。 其 关键 代码 如 下 : 


<2php 
ty{ 


关联 索引 


be 
<tr> 


</tr> 
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$pdo=new PDO($dsn, $user,$pwd); /实例 化 对 象 

$sql="select * from tb_pdo"; // 查 询 SQL 语句 
Sresult=$pdo->prepare($sq]):; // 准 备查 询 语句 
Sresult->execute(); // 执 行 查询 语句 ， 并 返回 结果 集 


while($res=$result->fetch(PDO::FETCH_ASSOC)){// 循 环 输出 查询 结果 集 ， 设 置 结果 集 为 


<td class="one"><?php echo S$res["id'];?></td> 

<td class="one"><?php echo S$res['‘username']:?></td> 

<td class="one"><?php echo S$res['userpwd']:?></td> 

<td class="one"><?php echo S$res['date']:?></td> 

<td class="one"><a href="index.php?id=<?php echo S$res["id"];?>"> 修 改 </a></td> 


其 次 ， 判 断 “ 修 改 ” 按 钮 是 否 被 单 击 ， 当 “修改 ”按钮 被 单 击 时 ， 获 取 地 址 栏 传 递 的 
参数 ， 根 据 参数 查询 数据 库 中 的 数据 ， 在 表格 最 下 方 动态 创建 <form> 表 单 ， 包 括 三 个 文本 
框 和 一 个 提交 按钮 ， 将 查询 到 的 数据 作为 表单 的 元 素 值 ， 并 设置 id 的 文本 框 为 只 读 。 


<form action="method="post"> 


<?php 


集 为 关联 索引 
?> 
<tr> 
</td> 


} 
ifisset($_GET[id])){ 
$sqls="select * from tb_pdo where id=".$_GET['id].""; 
Sresult=$pdo->prepare($sqls); /准备 查询 语句 
Sresult->execute(); // 执 行 查询 语句 ， 并 返回 结果 集 
while($sel=$result->fetch(PDO::FETCH_ASSOC)){// 循 环 输出 查询 结果 集 ， 设 置 结果 


<td class="one"><input readonly type='text name='id' value='<?php echo $sel['id"]:?>></td> 
<td class="one"><input type='text name=user value 一 <?php echo $sel[usemame']:?>></td> 
<td class="one"><input type= password name=pwd' value='<?php echo $sel[userpwd]:?>> 


<td class="one"><input type='text name='date' value='"<?php echo $sel['date']:?>'></td> 
<td class="one"><input class="two" type='submit name='subl' value 一 确定 ></td> 
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</tr> 
<?php 
} 
} 
Dx 
</form> 


最 后 ， 当 单 击 “确定 ”按钮 时 ， 获 取 表 单 提交 的 数据 ， 通 过 PDO 的 exec( 方 法 执行 更 | 
新 操作 。 其 代码 如 下 : | 


<?php 

iisset($_ POST['sublT)){ // 判 断 更 新 按钮 是 否 设置 | 

$sqles="update tb_pdo set username=".$ POST[muser].", userpwd=".$ POST[pwd]"，， 
date=".$_POST['date']." where id=".$_POST['id]."™": // 定 义 更 新 语句 | 
Sresu=$pdo->exec($sqles); // 执 行 更 新 语句 
if($resu—1){ 
echo "<script>alert(' 更 新 数据 成 功 ");window.location.href='index.php'</script>"; 

} 

} 


} catch (Exception $e) { 
echo "ERROR!!!".$e->getMessageQ."<br>"; // 返 回 错误 信息 


} 
> 
技术 要 点 


预 处 理 语句 包括 prepare0 和 execute() 两 个 方法 。 首 先 ， 通 过 prepare() 方 法 做 查询 的 准 
备 工 作 ， 然 后 ， 通 过 execute() 方 法 执行 查询 。 并 且 还 可 以 通过 bindParam() 方 法 来 绑 定 参数 | 
提供 给 execute( 方 法 。 其 语法 如 下 : | 
PDOStatement PDO::prepare ( string statement [, array driver_options] ) 
bool PDOStatement::execute ( [array input_parameters] ) 


多 学 两 招 : | 
预 处 理 语句 ， 它 是 要 运行 的 SQL 的 一 种 编译 过 的 模板 ， 它 可 以 使 用 变量 参数 进行 定 | 
制 。 预 处 理 语句 可 以 带 来 两 大 好 处 : | 

查询 只 需 解析 (或 准备 ) 一 次 ， 但 是 可 以 用 相同 或 不 同 的 参数 执行 多 次 。 当 查询 准备 | 
好 后 ， 数 据 库 将 分 析 、 编 译 和 优化 执行 该 查询 的 计划 。 对 于 复杂 的 查询 ， 这 个 过 程 要 花 比 | 
较 长 的 时 间 ， 如 果 需 要 以 不 同 参数 多 次 重复 相同 的 查询 ， 那 么 该 过 程 将 大 大 降低 应 用 程序 | 
的 速度 。 通 过 使 用 预 处 理 语句 ， 可 以 避免 重复 分 析 / 编 译 /优化 周期 。 简 言 之 ， 预 处 理 语句 | 
使 用 资源 更 少 ， 因 而 运行 得 更 快 。 | 

提供 给 预 处 理 语句 的 参数 不 需要 用 引号 括 起 来 ， 驱 动 程序 会 处 理 这 些 。 如 果 应 用 程序 
独占 地 使 用 预 处 理 语句 ， 那 么 可 以 确保 没有 SQL 入 侵 发 生 。 但是， 如 果 你 仍然 将 查询 的 
其 他 部 分 建立 在 不 受信 任 的 输入 之 上 ， 那 么 就 仍然 存在 风险 。 | 
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指点 迷津 : 
PDO 中 执行 SQL 语句 方法 的 选择 。 
(1 ) 如 果 只 是 执行 一 次 查询 ， 那 么 PDO->query 是 较 好 的 选择 。 虽 然 它 无 法 自动 转 义 
发 送 给 它 的 任何 数据 ， 但 是 它 在 遍历 SELECT 语句 的 结果 集 方面 是 非常 方便 的 。 然 而 在 使 
用 这 个 方法 时 也 要 相当 小 心 ， 因 为 如 果 没 有 在 结果 集中 获取 到 所 有 数据 ， 那 么 下 次 调用 
PDO->query 时 可 能 会 失败 。 
(2 ) 如 果 多 次 执行 SQL 语句 ， 那 么 最 理想 的 方法 是 prepare0 和 execute()。 这 两 个 方 


| 法 可 以 对 提供 给 它们 的 参数 进行 自动 转 义 ， 进 而 防止 SQL 注入 攻击 ; 同时 由 于 在 多 次 执 


| 行 SQL 语句 时 ， 应 用 的 是 预 编译 语句 ， 还 可 以 减少 资源 的 占用 ， 提 高 运行 速度 。 


实例 237 浏览 客户 留言 


( 实例 位 置 : 配套 资源 \SL\13W237 视频 位 置 配套 资源 \SP\13\237 ) 


| 实例 说 明 


| 本 实例 通过 PDO 中 的 fecth0 方 法 获取 河 贤 矢 户 留言 
| 结果 集中 下 一 行 的 数据 ， 进 而 应 用 while 语 未 3 


| 名 完成 数据 库 中 客户 留言 信息 的 循环 输出 ， 
| 同时 在 定义 SQL 语句 时 对 数据 按 ID 降 暴 排 
| 列 ， 显 示 4 条 记录 。 其 运行 效果 如 图 13.8 
| 所 示 。 


| 实现 过 程 


图 13.8 浏览 客户 留言 


具体 步骤 如 下 : 
(1) 创建 脚本 文件 index.php。 定 义 PDO 抽象 层 的 相关 参数 。 其 中 包括 $host、S$user、 
S$Spwd、$dbName、$dbms 等 。 
(2) 在 try...catch 语句 内 部 实例 化 PDO 对 象 ， 通 过 PDO 中 的 预 处 理 语句 prepare() 
和 execute0 执 行 SQL 查询 语句 ， 并 且 应 用 while 语句 和 fetch0 方 法 完成 数据 的 循环 输出 。 
其 代码 如 下 : 
<?php 
$dbms="mysql"; 
$user="root"; 
Spwd="111"; 
$host="localhost"; 
$dbName="db database13": 
$dsn="$dbms:host=$host:dbname=$dbName": 
try{ 
$pdo = new PDO(S$dsn, $user,$pwd); 
S$pdo->query("SET NAMES utf8"); // 设 置 编 码 格式 
$sql="select * from tb_fb order by id desc limit 4"; /定义 查询 语句 


“378 。 


$result=$pdo->prepare($sql); /准备 查询 语句 
Sresult->execute(); // 执 行 查询 语句 ， 并 返回 结果 集 


集 为 关联 案 引 
?> 
<tr> 
<td class="two"><?php echo $res[id];?></td> 
<td class="two"><?php echo S$res['title']:?></td> 
<td class="two"><?php echo S$res['content'];?></td> 
<td class="two"><?php echo S$res['date'];?></td> 
</tr> 
<2php 
} 
} catch (Exception $e) { 
echo "ERROR!!!".$e->getMessageQ)."<br>"; 


fetch() 方 法 获取 结果 集中 的 下 一 行 ， 其 语法 格式 如 下 : 
mixed PDOStatement::fetch ( [int fetch_style [, int cursor_orientation [, int cursor_offset]]] ) 


参数 说 明 : 
加 ”fetch_style: 控制 结果 集 的 返回 方式 ， 其 可 选 方式 如 表 13.1 所 示 。 
表 13.1 fetch_style 控制 结果 集 的 可 选 值 
值 说 了 明 

PDO::FETCH ASSOC | 关联 数组 形式 
PDO::FETCH NUM 数字 索引 数组 形式 
PDO::FETCH BOTH _| 两 者 数组 形式 都 有 ， 这 是 默认 的 
PDO::FETCH_OBJ 按照 对 象 的 形式 ， 类 似 于 以 前 的 mysql_fetch_obijectO 
以 布尔 值 的 形式 返回 结果 , 同时 将 获取 的 列 值 赋 给 bindParam0 〇 方法 中 指定 的 
变量 
PDO::FETCH LAZY | 以 关联 数组 、 数 字 索 引 数组 和 对 象 3 种 形式 返回 结果 


回 “cursor _ orientation: PDOStatement 对 象 的 一 个 滚动 游标 ， 可 用 于 获取 指定 的 一 行 。 
加 ”cursor_offset: 游标 的 偏 移 量 。 


PDO::FETCH_BOUND 


实例 238 明日 书店 会 员 注册 
( 实例 位 置 : 配套 资源 \SL\13\238 视频 位 置 配套 资源 \SP\13\238 ) 
实例 说 明 
本 实例 利用 PDO 抽象 层 知识 实现 明日 书店 会 员 注册 系统 。 其 核心 思想 是 拼接 插入 的 
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while($res=$result->fetch(PDO::FETCH_ASSOC)){// 循 环 输出 查询 结果 集 ， 并 且 设 置 结果 | 


| 图 13.9 明日 书店 会 员 注 册 
”实现 过 程 

首先 ， 创建 脚本 文件 index.php。 在 脚本 文件 中 编写 表单 ， 设 置 一 个 提交 按钮 和 一 个 重 
| 置 按 钮 。 其 次 ， 当 单 击 “注册 ”按钮 时 ， 首 先 通过 PDO 连接 MySQL 数据 库 ， 实 例 化 PDO 
| 对 象 并 利用 对 象 句 柄 调用 exec0 方 法 ， 向 数据 库 中 添加 数据 。 其 代码 如 下 : 


<?php 

$dbms= mysql'; 

$host='"localhost'; 

$user=root’; 

Spwd="111'; 

$dbName='db_database13"; 

$dsn="$dbms:host=$host:dbname=$dbName"; 

iflisset($_POST['sub])){ /判断 页 面 是 否 存在 sub 变量 

ty{ 
$pdo=new PDO($dsn, $user,$pwd); // 实 例 化 PDO 类 

| $sql="insert into tb_zc(usermame,userpwd,qq,email,date)values(".$_POST['text].",".$_POST 
| [pwd].", ".$_POST['qq].",".$_POST['mail].",".date("Y-m-d").")"; /定义 添加 语句 


$result=$pdo->exec($sql); /执行 添加 语句 
if($result—1){ 
echo "<script>alert(' 注 册 成 功 );</script>"; 
} 
} catch (Exception $e) { 
echo "ERROR".$e->getMessage(0."<br>": 
} 
上 
?> 
技术 要 点 


| 本 实例 通过 实例 化 PDO 对 象 并 应 用 exec0 方 法 执行 数据 库 插入 操作 , 根据 返回 的 结果 
| 集 Sresult 来 判断 用 户 是 否 注册 成 功 ， 如 果 返 回 的 结果 集 为 “1”， 则 说 明 用 户 注册 成 功 ， 否 
| 则 说 明 用 户 注册 失败 。 
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实例 239 添加 留言 信息 
( 实 便 位置 : 配套 资源 \SL\13W239 视频 位 置 配套 资源 \SP\13\239 ) 


实例 说 明 


本 实例 应 用 PDO 抽象 层 操作 MySQL 数据 库 , 实现 留言 信息 的 添加 功能 。 当 输入 标题 | 
和 内 容 后 ， 单 击 “ 发 布 ”按钮 ， 留 言 发 布 成 功 。 其 运行 效果 如 图 13.10 所 示 。 


添加 留言 
标题 : 私 风 薄 赤 ， 活 法 洒 起 ! 


留言 发 布 成 功 | 

图 13.10 添加 留言 信息 | 

实现 过 程 

首先 ， 创 建 脚本 文件 indexphp。 在 脚本 文件 中 编写 表单 ， 添 加 标题 的 文本 框 、 内 容 的 文 

本 域 以 及 “发 布 ” 按钮。 其 次 ， 当 单 击 “ 发 布 ”按钮 时 ， 首 先 通 过 PDO 连接 MySQL 数据 库 ， 
实例 化 PDO 对 象 并 利用 对 象 句柄 调用 exec0 方 法 ， 向 数据 库 中 添加 数据 。 其 代码 如 下 : 


<2php 
$dbms=mysql' /设置 数据 库 类 型 
$user='root'; // 定 义 数据 库 用 户 | 
Spwd="111'; /定义 数据 库 密码 | 
$host='localhost'; // 定 义 服务 器 | 


S$dbName='db database13: ””// 定 义 连接 数据 库 | 
$dsn="$dbms:host=$host:dbname=$dbName": 


ifisset($_POST['sub])){ /判断 发 布 按钮 是 否 被 设置 | 
ty { | 
$pdo = new PDO($dsn,$user, Spwd); // 实 例 化 PDO 类 | 
$pdo->query("SETNAMES utf8"); /设置 数据 库 编码 | 


$sql="insert into tb fb(title.content.date)values(".$ POST['title].", ".$ POST[content] "。 | 
"date("Ymdm | 


Srs=$pdo->exec($sql); /执行 添加 语句 | 
if$rs—"1"){ | 

echo "<b> 新 闻 发 布 成 功 </b>"; | 

} | 

} catch (Exception $e) { | 

echo "ERROR'".$e->getMessage0."<br>": | 

} 

} | 
?> ! 
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| 技术 要 点 

本 实例 应 用 query0 方 法 执行 SET NAMES utf8 语句 ， 设 置 页 面 的 编码 格式 ， 以 避免 用 
会 内 | 户 在 执行 添加 数据 操作 过 程 中 ， 向 数据 库 插入 乱码 ; 同时 也 避免 了 应 用 PDO 读 取 数据 时 ， 
Ne 在 页 面 中 显示 乱码 的 问题 。 
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实例 240 ”查询 留言 


( 实例 位 置 配套 资源 \SL\13\240 视频 位 置 : 配套 资源 \SP\13\240 ) 


| 本 实例 实现 了 一 个 站 内 搜索 的 功能 ， 对 站 内 的 留言 信息 进行 模糊 查询 。 通 过 PDO 中 
| 的 fecthAll0 方 法 获取 结果 集中 所 有 行 ， 并 且 通 过 for 语句 读 取 二 维 数组 中 的 数据 ， 完 成 查 
| 询 结果 的 循环 输出 。 其 运行 效果 如 图 13.11 所 示 。 


病 入 查询 内 容 查询 |] 


Ln ee =| EE 
11 自学 手册 自学 手册 非常 好 2010-11-25 


图 13.11 查询 留言 
现 过 程 


具体 步 又 如 下 : 

(1) 创建 脚本 文件 index.php。 定 义 表单 ， 提 交 查 询 的 关键 字 。 
| (2) 当 单 击 “ 查 询 ” 按 钮 时 ， 首 先 ， 判 断 查 询 关 键 字 是 否 为 空 ， 其 次 ， 使 用 PDO 抽 
| 象 层 连接 MySQL 数据 库 ,并 在 try..…catch 内 部 利用 PDO 对 象 句柄 调用 预 处 理 语句 prepareO 
| 和 execute0 执 行 模糊 查询 ， 最 后 应 用 fecthAll0 方 法 获取 结果 集中 所 有 行 ， 通 过 for 语句 循 
| 环 输 出 查询 结果 。 其 核心 代码 如 下 : 


<2php 
iisset($_POST[sub])){ // 判 断 查询 按钮 是 否 被 设置 

这 lisset($_POST['ext]) || $_POSTT['text] 一 "输入 查询 内 容 "){ /判断 查询 关键 字 是 否 为 真 
echo "文本 框 内 容 不 能 为 空 "; 

}else{ 
$dbms="mysql"; 
$user="root"; 
Spwd="111": 
$host="localhost"; 
$dbName="db_database13"; 
$dsn="$dbms:host=$host:dbname=$dbName"; 
ty{ 
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S$pdo = new PDO($dsn, $user, $pwd); /实例 化 PDO 类 
$sql="select * from tb fb where title like '%".$ POST['text]."%";// 定 义 查询 语句 
S$pdo->query("SET NAMES utf8"): // 设 置 编 码 格式 
$result=$pdo->prepare($sq)); // 准 备查 询 语 句 
Sresult->execute(); // 执 行 查询 语句 ， 并 返回 结果 集 
Sres=$result->fetchAll(PDO::FETCH_ASSOC); /获取 结果 集中 的 所 有 数据 。 
for(GSi=0:$i<count(Sres):SitH{ // 循 环 读 取 二 维 数组 中 的 数据 | 
> 
<t> | 
<td class="f"><?php echo $res[$il[id]:2></td> | 
<td class="f"><?php echo S$res[$i]["title'];?></td> | 
<td class="f"><?php echo $res[$il['content]:2></td> | 
<td class="f"><?php echo S$res[$il['date'];?></td> | 
</tr> | 
<?php | 
} | 
} catch (Exception $e) { | 
echo "ERROR".$e->getMessage()."<br>"; | 
) 
} 
} | 
?> | 


fetchAll0 方 法 获取 结果 集中 的 所 有 行 。 其 语法 如 下 : 

array PDOStatement: :fetchAll ( [int fetch_style [, int column_index]] ) 
参数 说 明 : 
fetch_style: 控制 结果 集中 数据 的 显示 方式 。 | 
回 “column index: 字段 的 索引 。 | 
其 返回 值 是 一 个 包含 结果 集中 所 有 数据 的 二 维 数组 。 | 
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Smarty 模板 


本 章 读 者 可 以 学 到 如 下 实例 : 


实例 241 
实例 242 
实例 243 
实例 244 
实例 245 
实例 246 
实例 247 
实例 248 
实例 249 
实例 250 
实例 251 
实例 252 


封装 Smarty 模板 的 配置 方法 

Smarty 模板 中 日 期 、 时 间 的 格式 化 输出 
Smarty 模板 中 的 编码 

Smarty 模板 制作 日 期 、 时 间 选 择 器 
通过 Section 循环 输出 数据 

开启 网 站 注册 页 面 的 缓存 

通过 配置 文件 定义 变量 
Smarty+ADODB 完成 数据 的 分 页 显示 
Smarty 模板 中 truncate() 方 法 截取 字符 事 
Register function() 方 法 注册 模板 函数 
Smarty 模板 中 的 关键 字 描 红 技 术 
Smarty 模板 中 生成 数字 验证 码 


需 
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实例 241 封装 Smarty 模板 的 配置 方法 
( 实例 位 置 : 配套 资源 \SL\14W241 视频 位 置 配套 资源 \SP\14\241 ) 
实例 说 明 


本 实例 中 向 读者 介绍 一 种 Smarty 模板 的 配置 方法 ， 人 
怎么 改变 ， 都 不 会 影响 到 实例 的 运行 。 其 运行 效果 如 图 14.1 所 示 。 


儿 开 务 雹 广 :400-675-1064 仙 当 志和 到 力 页 入 联 和 人 


[ETIZZETITIIETIITIITETITTITTIRECZZE 
明日 编程 词典 


[pL 给 程 同和 特点 


二 晶 亲 大 列 产品 是 所 和 要 全 和 生 估 程 太 开 发 和 员 全 开 反 
人 
ee 人 
re ei 社 
od TR ER 
技术 支社 ， 配 正 训 再 了 人 私人 坟 程 志 家 末 因 不 的 于 本 


明日 编程 词典 


图 14.1 应 用 封装 Smarty 模块 的 配置 方法 运行 程序 的 效果 图 

实现 过 程 
具体 步骤 如 下 : | 
(1) 在 实例 的 根 目录 下 创建 system 文件 来， 存储 Smarty 的 配置 文件 system.smarty， | 
incphp 和 实例 化 操作 文件 system.inc.php， 同 时 创建 Smarty 文件 夹 , 在 Smarty 文件 夹 下 创 | 
建 templates_c、configs 和 cache 3 个 目录 。 | 
(2) 创建 index.php 文件 ， 重 新 载 入 Smarty 的 配置 文件 ， 即 通过 include 语句 包含 | 
system.inc.php。 在 PHP 脚本 中 读 取 文本 文件 中 的 数据 , 并 将 其 赋 给 模板 变量 , 指定 模板 页 。 | 
其 关键 代码 如 下 | 


<2php 
header ( "Content-type: text/html: charset=UTF-8" ); // 设 置 文件 编码 格式 
include("system/system.inc.php"); // 包 含 配置 文件 


人 # ”使 用 Smarty 赋值 方法 将 一 对 名 称 /方法 发 送 到 模板 中 */ 
$smarty->assign('title', 第 一 个 Smarty 程序 ): 


$str = file_get_contents('files/content.txt'); // 读 取 文本 文件 中 的 数据 
$smarty->assign('content',iconv("gb2312","utf-8",$str));// 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
人 # 显示 模板 */ 

$smarty->display(index.html): 

?> 


(3) 编写 index html 模板 文件 ， 输 出 模板 变量 传递 的 数据 。 其 他 的 代码 请 参考 配套 资 | 
源 中 的 源 程序 ， 这 里 不 再 次 述 。 
为 了 让 读者 更 好 地 理解 smarty 模板 的 配置 方法 和 文件 的 存储 位 置 ， 下 面 给 出 本 实例 | 
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| 技术 要 点 
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的 文件 夹 架构 ， 如 图 14.2 所 示 。 


已 1 章 文件 夫 
日 - 思 ol 实例 根 文件 夫 
田 - 回 ess 
日 -已 files 读 取 的 文件 
目 content. txt 
回 images 
日 - 回 :ysten 
日 - 回 snarty Smarty 读 取 文件 夹 
由 -加 cache 组 存 文件 夫 
DD confies 配置 文件 夫 
由- 回 templates_e 编译 文件 文件 夫 
司 systen ine. php 类 的 实例 化 文件 
司 systen. smarty. ine. php Smarty 模 板 配置 类 封装 
十 inaex. html 模板 文件 
司 index. php 动态 mi 文 件 
田 -加 lits Smarty 类 库 文件 夫 


图 14.2 ”实例 241 的 文件 夹 架 构 


这 里 将 Smarty 配置 方法 封装 到 类 中 ， 并 存储 到 system.smarty.inc.php 文件 中 。 首 先 ， 


包含 Smarty 类 文件 Smarty.class.php; 然后 ， 定 义 SmartyProject 类 ， 继 承 Smarty 父 类 ; 最 
| 后 ,定义 SmartyProject() 方 法 , 设置 Smarty 中 模板 文件 (templates)、 编 译文 件 (templates_c)、 
| 配置 文件 (configs) 和 缓存 文件 (cache) 的 存储 位 置 。 这 就 是 新 的 配置 文件 system smarty 
| inc.php， 其 代码 如 下 : 


<2php 


require("../libs/Smarty.class.php"); 
class SmartyProject extends Smarty{ 
function SmartyProjectO{ 
S$this->template_dir = "./"; 


S$this->compile_dir = "./system/Smarty/templates_c/"; 


// 调 用 Smarty 文件 

// 定 义 类 ， 继 承 Smarty 父 类 

// 定 义 方法 ， 配 置 Smarty 模板 

// 指 定 模板 文件 存储 在 根 目录 下 

// 指 定编 译文 件 存储 位 置 


S$this->config dir ="./system/Smarty/configs/"; 
S$this->cache_dir = "./system/Smarty/cache/"; 


} 
b 


?> 


既然 已 经 将 Smarty 的 配置 方法 存储 到 一 个 类 中 ， 那 么 就 需要 对 类 进行 实例 化 ， 根 据 


返 
返回 对 象 名 为 Ssmarty。 其 代码 如 下 : 
<?php 
require("system.smarty.inc.php"); 
$smarty=new SmartyProject(); 
?> 


回 的 对 象 名 称 调用 Smarty 中 的 方法 ， 类 的 实例 化 操作 在 system.inc.php 文件 中 完成 ， 其 


// 调 用 类 文件 
// 执 行 类 的 实例 化 操作 


通过 此 方法 配置 Smarty 模板 的 好 处 是 : 无 论 将 程序 复制 到 哪个 服务 器 下 执行 ， 都 不 
需要 更 改 服 务 器 或 者 Smarty 文件 的 绝对 路 径 ， 程 序 都 可 以 直接 运行 。 
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指点 迷津 : | 
这 种 配置 方法 中 调用 的 是 存储 在 目录 14 下 的 libs 文件 天 中 的 Smarty 类 库 ， 同 时 在 这 | 
种 方法 中 将 配置 文件 存储 于 实例 根 目录 下 的 system 文件 夹 中 ， 将 模板 文件 夹 ( templates )、 | 
编译 文件 来 (templates c )、 配 置 文件 夹 ( configs ) 和 缓存 文件 夹 ( cache ) 存 储 在 system\Smarty | 


目录 下 。 | 


实例 242 ”Smarty 模板 中 日 期 、 时 间 的 格式 化 输出 


( 实例 位 置 : 配套 资源 \SL\14\242 ) 


实例 说 明 


在 PHP 脚本 中 日 期 、 时 间 的 格式 化 输出 最 常用 的 就 是 date0 函 数 ， 那么 在 smzarty 模板 | 
中 该 如 何 完成 日 期 、 时 间 的 输出 呢 ? 这 就 是 本 实例 中 要 讲解 的 内 容 ， 通 过 Smarty 模板 中 | 
的 date_format() 函 数 完成 日 期 、 时 间 的 格式 化 输出 ， 其 运行 结果 如 图 14.3 所 示 。 


,用 日 购物 空间 


前 5 | 试用 | 痘 录 | 了 kB | 珊 呈 虹 不 | 公告 


ee ee 
路 "a 


首 而 上 -页 下 一再 是 而 


图 14.3 Smarty 模板 中 日 期 的 格式 化 输出 
实现 过 程 


本 实例 首先 创建 一 个 index.html 模板 页 面 ， 然 后 在 index.html 并 本 文件 中 折 入 
date_format() 函 数 ， 并 输出 系统 的 当前 时 间 。 其 关键 代码 如 下 : 


<td width="480" height="18" align="left"> 当 前 时 间 : {$smarty.nowldate format:" %A %B -%e- | 

%Y"}</td> | 
<!--{$smarty.nowldate format} 
{$smarty.nowldate_format:"%A, %B %e, %Y":$times} 
{$smarty.nowldate_format:"%H:%M:%S"} 
{$yesterdayldate_format} 
{$yesterdayldate_format:"%A, %B %e, %Y"} 


> 
本 实例 的 其 他 内 容 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 再 袭 述 。 
技术 要 点 


(1) Smarty 模板 中 的 date_format0 函 数 ， 格 式 化 从 函数 stftime0 获 得 的 时 间 和 日 期 。| 
3687 Le 
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”其 应 用 示例 如 下 : 


| {$smarty.nowldate format:"%A, %B %e, 9%6Y":$times} 
| 加 ”$smarty.now: 传递 给 date_format() 的 数据 。 这 个 参数 可 以 是 在 PHP 动态 页 中 定义 
的 日 期 .时 间 模 板 变量 ,也 可 以 使 用 Smarty 中 的 保留 变量 $smarty.now 或 者 Smarty 
| 模板 中 的 日 期 。 
| 回 ”%A, %B %e, %Y: date_format() 函 数 执行 格式 化 操作 时 使 用 的 格式 。 
$times: 当 传 递 给 date_format0 的 数据 为 空 时 ， 通过 $times 设置 date_format() 格 式 


化 的 默认 值 。 
(2) date_format0) 函 数 可 以 使 用 的 转换 格式 很 多 ， 其 常用 的 转换 格式 说 明 如 下 : 

%a - 根据 当地 格式 输出 “星期 ”缩写 格式 

%A - 根据 当地 格式 输出 “星期 ”全 称 格式 

%b - 根据 当地 格式 输出 “月 ”缩写 格式 

%B - 根据 当地 格式 输出 “月 ”全 称 格式 

%Y - 根据 当地 格式 输出 “年 ”全 称 格式 
| 要 了 解 date_format0 函 数 所 有 可 以 使 用 的 转换 格式 , 建议 读者 参考 Smarty 模板 的 参考 
| 手册 。 


实例 243 Smarty 模板 中 的 编码 


( 实例 位 置 : 配套 资源 \SL\14\243 ) 


说 明 
| 在 PHP 脚本 中 应 用 urlencodeO 函 数 对 超 链 接 中 传递 的 参数 进行 编码 ， 而 在 Smarty 模 
| 板 中 提供 escapeO 函 数 对 字符 串 进 行 编码 。 在 本 实例 就 详细 地 讲解 一 下 这 个 函数 的 应 用 ， 
| 通过 它 完 成 对 超级 链接 中 传递 的 参数 进行 编码 ， 其 运行 结果 如 图 14.4 所 示 。 


Pas 
| 


| 图 14.4 Smarty 模板 中 对 超 链 接 的 参数 值 进行 编码 

| 实现 过 程 

| 具体 步骤 如 下 ; 

(1) 这 里 首先 创建 一 个 台 管理 系统 主页 的 模板 ， 为 不 同 模块 之 问 跳 转 的 超 链接 传递 
。388 .。 


的 参数 值 进行 编码 ， 其 具体 的 操作 在 main .html 模板 页 中 完成 ， 关 键 代 码 如 下 : 


<map name="Map" id="Map"> 


<area shape="rect" coords="29,41,88,62” href="main.php?caption={" 商 品 添加 "|escape:"url"} &amp; 


type= 人 商品 管理 "}" /> 


<area shape="rect" coords="30,71,91,90" href="main.php?caption={" 商 品 修改 "|escape:"url"}&amp; 


type= 人 商品 管理 )" 放 


<area shape="rect" coords="31,99,91,118" href="main.php?caption={" 商 品 删 除 "|escape:"url"}&amp; 


type={" 商 品 管理 "}" 户 
</map> 
<map name="Map2" id="Map2"> 


<area shape="rect" coords="30,45,97,63" | 


type= 人 + 会 员 管理 "}" /> 


<area shape="rect" coords="34,80,89,98" href="main.php?caption={" 会 员 浏 览 "lescape:"url"}&amp; 


type={" 会 员 管理 "}" /> 
</map> 
<map name="Map5" id="Map5"> 


<area shape="rect" coords="12,11,54,36" href="logout.php" /> 


</map> 
<map name="Map6" id="Map6"> 


<area shape="rect" coords="14,12,51,36" href="main.php?caption={" 商 品 修改 "lescape:"url"}&amp; 


type={f 商 品 管理 "|escape:"url"}" 这 
</map> 


(2) 虽然 通过 escape0) 编 码 后 的 模板 变量 输出 时 是 


块 的 内 容 。 不 需要 对 这 个 参数 值 进行 解码 。 


乱码 ， 但 是 在 switch 语句 中 仍然 可 
以 直接 使 用 $_GET['caption] 获 取 超 链接 的 值 ， 根 据 这 个 值 作 出 判断 ， 在 主页 中 输出 那个 模 | 


执行 判断 是 在 main.php 文件 中 完成 的 ， 其 关键 代码 如 下 : 


<2php 
Session_startO; 
这 $_SESSION[user]!="" and $ SESSION[pass']!="){ 
require("system/system.inc.php"); 
switch ($_GET['caption']){ 
case "商品 添加 
include "sho_insert.php": 
$smarty->assign('admin_ phtml','sho_insert.html’); 
给 模板 变量 
break:; 
/省 略 了 部 分 代码 
default: 
include "sho_update.php"; 


$smarty->assign(admin phtml','sho_update.html"); 


break: 
} 


// 初 始 化 SESSION 变量 

/判断 用 户 名 和 密码 是 否 为 空 
/包含 PHP 配置 文件 

/根据 超 链 接 传递 的 值 进行 判断 


/包含 PHP 文件 


/将 PHP 文件 对 应 的 模板 文件 的 名 称 赋 


// 跳 出 循环 


$smarty->assign("title"," 后 台 管 理 系统 --".$_GET['caption'"])); /为 模板 变量 赋值 


$smarty->assign("caption",$_GET['caption']); 
$smarty->assign("type",$ GET['type]); 
$smarty->assign("user",$_ SESSION[user]): 


"389 。 


/为 模板 变量 赋值 ， 输 出 模块 名 称 
/为 模板 变量 赋值 ， 输 出 模块 所 属 类 别 
/为 模板 变量 赋值 ， 输 出 登录 用 户 名 称 
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$smarty->display("main.html"): /指定 模板 页 
jelse{ 
echo "<script>alert(' 您 不 具备 访问 权限 ! ): window.location.href~'index.html';</script>"; 


| a 


| escape( 函 数 用 于 html 转 码 、url 转 码 ， 在 没有 转 码 的 变量 上 转换 单 引号 、 十 六 进 制 转 
| 码 或 者 javascript 转 码 。 默 认 是 html 转 码 。 其 基本 的 应 用 格式 如 下 : 
| {$articleTitlelescape} 

{$articleTitlelescape:"html"} {* escapes &"'<>*} 

{$articleTitlelescape:"htmlall"} {* escapes ALL html entities *} 

{$articleTitlelescape:"url"} 

{$articleTitlelescape:"quotes"} 

<a href="mailto: {$EmailAddresslescape:"hex"}">{$EmailAddresslescape:"hexentity"}</a> 


实例 244 Smarty 模板 制作 日 期 、 时 间 选 择 器 


( 实例 位 置 : 配套 资源 \SL\14\244 ) 


| 实例 说 明 


| 时 间 处 理 函 数 ,通过 它们 可 以 得 到 不 同 格式 \ 
| 的 日 期 、 时 间 信 息 。 在 本 实例 中 将 应 用 人 Bm: [raw 司 [本 所 可 
| Smarty 模板 中 的 日 期 时 间 选 择 函数 ， 设 计 | aa:[ 相 [本 而 习 ， 
| -个 日 期 时 间 选 择 器 ， 记 录用 户 登录 的 时 1 ps b 
| 间 。 其 运行 结果 如 图 14.5 所 示 。 1 ， 
| 实现 过 程 : ， 
| 有 具体 步骤 如 下 : TOS GA 
(1) 创建 system 文件 夹 。 首 先 ， 定 义 a a 


system.smarty.inc.php 文件 ， 封 装 Smarty 的 图 14.5 Smarty 模板 制作 日 期 、 时 间 选择 器 
| 配置 方法 以 及 ADODB 连接 和 操作 数据 库 
| 的 方法 。 然 后 ， 定 义 system.inc.php 文件 ， 对 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 进行 
| 实例 化 ， 并 返回 连接 对 象 。 最 后 ， 创 建 Smarty 文件 夹 ， 定 义 Smarty 的 编译 文件 、 配 置 文 
| 件 和 缓存 文件 的 存储 目录 。 
| (2) 创建 index.php 文件 。 首 先 ， 设 置 页 面 的 编码 格式 、 载 入 配置 文件 。 然 后 ， 生 成 
| 随机 验证 码 ， 并 且 将 随机 验证 码 的 值 赋 给 模板 变量 。 最 后 ， 指 定 index.html 模板 页 。 其 代 
| 码 如 下 
| <2php 

header ( "Content-type: text/html; charset=UTF-8" ); // 设 置 文件 编码 格式 
J . 390. 
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require_once("system/system.inc.php"): // 包 含 配置 文件 

S$array= explode(' ', mt_rand(1000,9999)); // 生 成 随机 验证 码 
$smarty->assign('title','Smarty 模板 制作 日 期 、 时 间 选 择 器 ); // 将 指定 数据 赋 给 模板 变量 
S$smarty->assign('content’, $array): // 将 数组 赋 给 模板 变量 
$smarty->display('index.html'): /指定 模板 页 

?> 


(3) 创 建 mdex.html 模板 页 , 设计 用 户 登录 的 form 表单 .其 中 , 应 用 html _ select date( 
和 html_select_time() 函 数 生 成 日 期 时间 下 拉 列 表 框 ， 应 用 foreach 语句 输出 验证 码 ， 最 终 
将 表单 中 数据 提交 到 index_ok.php 文件 中 ， 完 成 用 户 登 录 的 操作 。 其 关键 代码 如 下 : 


<form id="form" name="form" method="post"” action="index_ ok.php" onsubmit="return check 
form0; "> 
日 期 : {html select_date} 
时 间 : {html_select_time use 24 hours=true} 
用 户 名 : <input name="user" type="text" id="user" size="20" /> 
密码 : <input name="pass" type="password" id="pass" size="20" /> 
验证 码 : <input type="hidden" id="checks" name="checks" value="{foreach key=key 
item=item from=$content} {$item} {/foreach}" /> 
<input name="check" type="text" id="check" size="8" />{foreach key=key item=item 
from=$content} {$item)} {/foreach} 
<input type="image" name="imageField3" src="images/reg_07.jpg" /> 
<input type="image" name="imageField4" onclick="form.reset();return false;" src="images/ 
reg 09.jpe" /> 
</form> 


(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 用 户 登 录 信 息 ， 定 义 查 询 语句 验证 
用 户 提交 的 用 户 名 和 密码 是 否 正 确 ， 如 果 正确 则 根据 日 期 、 时 间 选 择 器 中 提交 的 数据 ， 更 
新 用 户 注册 信息 表 中 的 最 后 登录 时 间 。 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html: charset=UTF-8" ): /设置 文件 编码 格式 
require_once("system/system.inc.php"): // 包 含 配 置 文 件 


if($_POST['user']!=""&&$_POST['pass']!=""&&$ POST['checks']!=""){ 
$sql="select * from tb user Where user=".$ POST[user].” and pass=".md5($ POST 
[passD 
Sres=$admindb->ExecSQL($sql,$conn): // 执 行 select 查询 语句 
if($res){ 
$login date=$ POST['Date_Year]."-".$ POST[Date Month']."-".$_ POST[Date Day']." 
"$_ POST[Time Hour].":".$_ POST[Time Minute’].":".$ POST[Time Second']: 
$sqls="update tb_user set login date=".$login date." where user=".$ POST[user]." 
and pass=".md5($ POST[pass])."": 


S$rs=$admindb->ExecSQL($sqls, $conn): // 执 行 update 更 新 语句 
echo "<script>alert( 用 户 登 录 成 功 ! ); window.location.hre 人 ='main.php';</script>"; 
}else{ 
echo "<script>alert( 用 户 登 录 失 败 ! ); window.location.href='index.php';</script>"; 
} 
}else{ 
echo "<script>alert( 用 户 登 录 信息 不 可 为 空 ! ); window.location.href='index.php';</script>"; 
1 
> 


“394。 
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SS 
(5) 创建 main php 和 main html 文件 ， 作 为 用 户 登 录 成 功 的 跳 转 页 面 ， 其 代码 请 参考 
| 本 书 配套 资源 。 

| 技术 要 点 

医 靖 在 Smarty 模板 中 通过 自 定义 函数 html select_ date0 和 html select timeO 生 成 日 期 、 时 


间 选 择 器 。 


| html_select_dateO) 函 数 ， 用 于 创建 日 期 下 拉 菜 单 ， 可 以 显示 任意 年 月 日 。html select_ 
;date() 函 数 的 语法 说 明 如 表 14.1 所 示 。 


| 表 14.1 html_select_date() 函 数 的 语法 说 明 

| 属性 说 明 

ear size 如 果 设置 ， 为 标签 添加 大 小 属性 

all extra rr i 7 如 果 设置 ， 为 所 有 标签 添加 附加 属性 
day extra rl 如 果 设置 ， 为 标签 添加 附加 属性 
month extra | ti | | 如 果 设 置 ， 为 标签 添加 附加 属性 

ear extra i | | 如 果 设 置 ， 为 标签 添加 附加 属性 
field_order | sting | No | MDY | 显示 区 域 的 顺序 

field_separator | sting | No |m | 各 区 域 间 输 出 的 分 隔 字符 串 

month value_format 月 份 值 的 strftime 表示 方法 ， 默 认为 %m 
ear size 如 果 设 置 ， 为 标签 添加 大 小 属性 


html_select_time0 函 数 ， 创 建 时 间 下 拉 菜 单 ， 它 可 以 显示 任意 时 分 秒 。html_select_time() 
函数 的 语法 说 明 如 表 14.2 所 示 。 


表 14.2 ”html_select time() 函 数 的 语法 说 明 
属性 | 类 型 | 是 否 必 须 说 明 
i 变量 名 称 前 绥 
time | timestamp | No | UNIX | 使 用 时 间 类 型 (datatime) 
display hours | booean | No | me | 是 否 显示 小 时 
display minutes 一 是 否 显示 分 钟 


display_seconds boolean 是 显示 秒 
display_meridian | 。 boolean 否 显示 正午 界 (上 午 /下 午 ) 
| _use 24 hours boolean 十 否 使 用 24 小 时 制 
| minute_interval integer 分 钟 下 拉 列 表 的 间隔 
| second interval integer 秒 钟 下 拉 列 表 的 间隔 
| _field amay string 输出 值 到 该 值 指定 的 数组 
| _all extra ing 如 果 设 置 ， 为 标签 添加 附加 属性 
| _hour extra 如 果 设 置 ， 为 标签 添加 附加 属性 


如 果 设 置 ， 为 标签 添加 附加 属性 
如 果 设 置 ， 为 标签 添加 附加 属性 
如 果 设 置 ， 为 标签 添加 附加 属性 


minute_extra 


second_ extra 


meridian extra 
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实例 245 通过 Section 循环 输出 数据 


( 实例 位 置 : 配套 资源 \SL\14\245 视频 位 置 配套 资源 \SP\14\245 ) 


实例 说 明 

在 PHP 动态 页 中 ， 可 以 通过 while、do...while、for 和 foreach 语句 实现 数据 的 循环 输 
出 ， 而 在 Smarty 中 它 也 有 属于 自己 的 循环 输出 语句 foreach 和 section。 在 本 实例 中 将 介绍 
通过 section 语句 完成 数据 的 循环 输出 ， 运 行 结果 如 图 14.6 所 示 。 


一 一 =- 管理 员 : 分 首页 人 @ 退出 
< 二 i 
明日 购物 空 闻 I 三 ) 三 3 
人 国电 自 ，2010 下 08 月 14 日 ee 
[入 会 吴 是 理 -> 会 员 沪 笑 
EE gd 
| nm 会 员 名 称 Email 注 扣 时 间 
和 四 | passlo3asin em | 2010-08-09 
商品 修改 2 | Tanksikaal1038sxina com | 2010-06-09 
FTCT 国 区 rotarsoft co | 2010-00-14 
9 会员 抽 院 
会 员 济 中 


图 14.6 通过 section 循环 输出 数据 
实现 过 程 
具体 步骤 如 下 : 
(1) 本 实例 应 用 开发 的 后 台 管 理 系统 主页 为 基础 ， 首 先 去 除 后 台 管 理 系 统 的 登录 功 
能 ， 直 接 在 index.php 和 index.html 中 创建 后 台 管 理 系统 的 主页 ， 在 switch 语句 中 ， 将 
Vip_look.php 和 vip_look.html 设置 为 默认 值 。index.php 的 关键 代码 如 下 : 


<7php 
require("system/system.inc.php"): 
switch ($_GET['caption']){ 
case "会 员 删 除 "; 
include "vip_delete.php"; 
$smarty->assign(admin phtml','vip_delete.html"); 
break:; 
case "会 员 浏 览 "; 
include "vip_look.php"; 
$smarty->assign(admin phtml','vip_look.html"); 
break: 
/省 略 了 部 分 代码 
default: 
include "vip_look.php"; 
$smarty->assign(admin_ phtml',vip_lookhtml); 
break: 
} 


"393。 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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$smarty->assign("title"," 后 台 管 理 系统 --Section 循环 输出 数据 --".$_GET['caption']); 
i($_GET['caption]!="){ 
$smarty->assign("caption",$_GET['caption"]); 
$smarty->assign("type",$_GETT['type']): 
}else{ 
$smarty->assign("caption"," 会 员 浏 览 "); 
$smarty->assign("type"," 会 员 管 理 "); 


ee 年 m 月 d 日 ")); 
$smarty->display("index.html"): 
?> 
(2) 在 本 实例 中 对 会 员 浏 览 模块 (vip look.php 和 vip_ lookhtml) 进行 实际 地 开发 。 
即 应 用 section 语句 循环 输出 数据 库 中 存储 的 会 员 信息 。 
首先 ， 重 新 创建 vip_look.php 文件， 定义 SQL 语句 ， 调 用 数据 库 操作 类 (AdminDB) 
中 的 ExecSQL 方法 ， 查 询 出 数据 库 中 的 会 员 数 据 ， 并 且 将 返回 的 数组 赋 给 指定 的 模板 变 
量 。 其 代码 如 下 : 


<?php 
$sql="select * from tb_user "; // 定 义 SQL 查询 语句 
Sres=$admindb->ExecSQL($sql,$conn):; // 执 行 查询 操作 
if($res){ 

$smarty->assign("res",$res):; // 将 查询 结果 赋 给 指定 的 模板 变量 
} 
> 


然后 ， 重 新 创建 vip_look.html 文件 ， 应 用 section 语句 循环 输出 模板 变量 中 传递 的 会 
员 数 据 。 其 关键 代码 如 下 : 


{section name=id loop=$res} 
<tr> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"center" bgcolor="#FFFFFF">{$res[id].id}</td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].user} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px:;" align= 
"left" bgcolor="#FFFFFF">{$res[id].email} </td> 
<td style="padding-bottom:5px; padding-left:5px; padding-right:Spx: padding-top:5px;" align= 
"left" bgcolor="#FFFFFF">{$res[id].dates} </td> 
</t> 
{/section} 


本 实例 的 重点 在 于 讲解 如 何 通过 section 语句 循环 输出 数组 中 的 数据 , 至 于 其 他 内 容 读 
者 可 以 参考 配套 资源 中 的 源 程序 ， 这 里 不 做 讲解 。 


技术 要 点 
section 循环 语句 ， 用 于 比较 复杂 的 数组 。section 的 语法 如 下 : 


{section name="sec_name" loop=$arr name start-num step=num} 
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参数 说 明 : 
name: 表示 循环 的 名 称 。 
loop: 表示 循环 的 数组 。 | 
start: 表示 循环 的 初始 位 置 ， 如 果 start=2， 那 么 说 明 循环 是 从 loop 数组 的 第 2 个 | 会 凡 
元 素 开 始 。 | Ya 
step: 表示 步 长 ， 如 果 step=2， 那 么 循环 一 次 后 ， 数 组 的 指针 将 向 下 移动 两 位 ， Note 
以 此 类 推 。 | 
Section 循环 语句 读 取 的 是 存储 在 模板 变量 中 的 数组 元 素 , 而 这 个 数组 元 素 值 是 在 动态 | 
PHP 文件 中 通过 调用 数据 库 操作 类 中 的 Sadmindb->ExecSQL 方法 获取 的 。 | 
究 其 根源 就 是 应 用 ADODB 类 库 中 的 GetRows0 方 法 获取 的 查询 结果 ， 有 关 其 具体 的 设 | 
置 可 以 参考 封装 的 数据 库 操作 类 AdminDB, 该 类 存储 于 system\system.smarty.inc.php 文件 中 。 | 


实例 246 开启 网 站 注册 页 面 的 缓存 


( 实例 位 置 : 配套 资源 \SL\14\246 ) 


实例 说 明 

缓存 的 合理 应 用 ， 应 该 以 实际 的 开发 需要 为 依 
据 ， 对 于 那些 需要 经 常 更 新 的 程序 是 否 开 局 缓存 ， 
如 果 开 局 缓存 ， 周 期 长 短 设置 多 长 时 间 ， 这 些 都 必 
须根 据 程序 的 实际 需求 进行 设置 。 在 本 实例 中 开启 
网 站 注册 页 面 的 缓存 ,注册 页 面 的 运行 结果 如 图 14.7 
所 示 。 


实现 过 程 
首先 创建 本 实例 应 用 的 首页 模板 ， 然 后 创建 一 By 区 


个 指向 模板 的 处 理 页 ， 完 成 用 户 注册 的 功能 ， 并 且 
开启 用 户 注 册页 面 的 缓存 。 有 关 缓 存 的 设置 在 动态 
处 理 页 index.php 中 完成 ， 其 代码 如 下 : 


图 14.7 开启 网 站 注册 页 面 的 缓存 


<?php 

header ( "Content-type: text/html: charset=UTF-8" ): // 设 置 文件 编码 格式 
require_once("system/system.inc.php"): // 包 含 配置 文件 
$smarty->caching=true: // 开 启 缓存 
$smarty->cache lifetime=3600: // 设 置 缓存 过 期 时 间 
//$smarty->clear all_ cache0: /清除 所 有 缓存 
if(!$smarty->is_cached('index.html")){ 

S$res=$conn->execute("select * from tb_bccd "): // 执 行 select 查询 语句 
$array=$res->GetArray(); 


$array_1d=array(); 
Sarray_name=array(); 
for($i=0;$i<$res->RecordCount(O:$i1++){ 
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参数 说 明 : 
name: 表示 循环 的 名 称 。 
loop: 表示 循环 的 数组 。 | 
start: 表示 循环 的 初始 位 置 ， 如 果 start=2， 那 么 说 明 循环 是 从 loop 数组 的 第 2 个 | 会 凡 
元 素 开 始 。 | Ya 
step: 表示 步 长 ， 如 果 step=2， 那 么 循环 一 次 后 ， 数 组 的 指针 将 向 下 移动 两 位 ， Note 
以 此 类 推 。 | 
Section 循环 语句 读 取 的 是 存储 在 模板 变量 中 的 数组 元 素 , 而 这 个 数组 元 素 值 是 在 动态 | 
PHP 文件 中 通过 调用 数据 库 操作 类 中 的 Sadmindb->ExecSQL 方法 获取 的 。 | 
究 其 根源 就 是 应 用 ADODB 类 库 中 的 GetRows0 方 法 获取 的 查询 结果 ， 有 关 其 具体 的 设 | 
置 可 以 参考 封装 的 数据 库 操作 类 AdminDB, 该 类 存储 于 system\system.smarty.inc.php 文件 中 。 | 


实例 246 开启 网 站 注册 页 面 的 缓存 


( 实例 位 置 : 配套 资源 \SL\14\246 ) 


实例 说 明 

缓存 的 合理 应 用 ， 应 该 以 实际 的 开发 需要 为 依 
据 ， 对 于 那些 需要 经 常 更 新 的 程序 是 否 开 局 缓存 ， 
如 果 开 局 缓存 ， 周 期 长 短 设置 多 长 时 间 ， 这 些 都 必 
须根 据 程序 的 实际 需求 进行 设置 。 在 本 实例 中 开启 
网 站 注册 页 面 的 缓存 ,注册 页 面 的 运行 结果 如 图 14.7 
所 示 。 


实现 过 程 
首先 创建 本 实例 应 用 的 首页 模板 ， 然 后 创建 一 By 区 


个 指向 模板 的 处 理 页 ， 完 成 用 户 注册 的 功能 ， 并 且 
开启 用 户 注 册页 面 的 缓存 。 有 关 缓 存 的 设置 在 动态 
处 理 页 index.php 中 完成 ， 其 代码 如 下 : 


图 14.7 开启 网 站 注册 页 面 的 缓存 


<?php 

header ( "Content-type: text/html: charset=UTF-8" ): // 设 置 文件 编码 格式 
require_once("system/system.inc.php"): // 包 含 配置 文件 
$smarty->caching=true: // 开 启 缓存 
$smarty->cache lifetime=3600: // 设 置 缓存 过 期 时 间 
//$smarty->clear all_ cache0: /清除 所 有 缓存 
if(!$smarty->is_cached('index.html")){ 

S$res=$conn->execute("select * from tb_bccd "): // 执 行 select 查询 语句 
$array=$res->GetArray(); 


$array_1d=array(); 
Sarray_name=array(); 
for($i=0;$i<$res->RecordCount(O:$i1++){ 
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S$array_id[]=$array[$i][id]; 
S$array_name[]=$array[$i][name]l: 


} 

S$smarty->assign('cust_id', Sarray id): /设置 下 拉 列表 的 值 
$smarty->assign('cust_name', $array_name): /设置 列表 的 显示 数据 

} 

$array= explode('', mt rand(1000,9999)): // 生 成 随机 验证 码 
$smarty->assign('title',' 开 启 网 站 注册 页 面 的 缓存 "); // 将 指定 数据 赋 给 模板 变量 
$smarty->assign('content', $array): // 将 数组 赋 给 模板 变量 
$smarty->assign('contents',$arrays); // 将 数组 赋 给 模板 变量 
$smarty->display('index.html’); // 指 定 模板 页 

> 


缓存 文件 存储 在 system\Smarty\cache 目录 下 ， 而 存储 路 径 的 设置 是 在 system\system. 


| smartyinc php 文件 中 完成 。 有 关 用 户 注册 的 其 他 功能 ， 请 读者 参考 配套 资源 中 的 源 程序 ， 
| 这 里 不 再 獒 述 。 


| 技术 要 点 


缓存 的 设置 ， 既 要 考虑 网 站 访问 速度 的 提高 ， 又 要 考虑 缓存 生命 周期 的 合理 性 。 不 能 


偏执 一 方 ， 应 该 采取 中 庸 之 道 ， 达 到 一 个 最 理想 的 效果 。 


例如 ， 网 站 首页 是 不 需要 经 常 更 新 的 内 容 ， 缓 存 的 生存 周期 就 可 以 设置 长 一 些 ， 而 类 
似 于 论坛 中 帖子 的 数据 ， 则 可 以 不 开启 缓存 ， 因 为 帖子 的 数据 会 不 断 更 新 ， 就 没有 必要 再 
使 用 缓存 ， 如 果 使 用 缓存 可 能 会 导致 浏览 不 到 最 新 的 数据 。 
(1) 开启 缓存 。 
开启 缓存 的 方法 非常 简单 ， 只 要 将 Smarty 对 象 中 $config 的 值 设置 为 true 即 可 ， 同 时 
还 要 通过 Smarty 对 象 中 的 $cache_dir 属性 指定 缓存 文件 的 存储 位 置 。 其 操作 代码 如 下 : 
S$smarty->caching=true; /开启 缓存 
$smarty->cache_dir =BASE PATH .SMARTY _ PATH.cache/: /定义 缓存 文件 存储 位 置 
(2) 设置 缓存 生命 周期 。 
缓存 创建 成 功 后 ， 必 须 为 它 设置 一 个 生命 周期 ， 如 果 它 一 直 不 更 新 ， 那 么 就 没有 任何 
意义 。 设 置 缓存 生命 周期 应 用 的 是 Smarty 对 象 中 的 Scache_lifetime 属性 ， 缓 存 时 间 以 秒 为 
单位 ， 默 认 值 是 3600 秒 。 其 操作 代码 如 下 : 


$smarty->cachine=true; /开启 缓存 
$smarty->cache dir= BASE PATH .SMARTY PATH.cache/: /定义 缓存 文件 存储 位 置 
$smarty->cache lifetime=3600 // 设 置 缓存 时 间 为 1 小 时 


(3) 判断 模板 文件 是 否 已 经 被 缓存 。 
如 果 页 面 已 经 被 缓存 ， 那 么 就 可 以 直接 调用 缓存 文件 ， 而 不 再 执行 动态 获取 数据 和 输 
出 的 操作 。 为 了 避免 在 开启 缓存 后 ， 再 次 执行 动态 获取 数据 和 输出 操作 给 服务 器 带 来 的 压 
力 , 最 佳 的 方法 就 是 应 用 Smarty 对 象 中 的 is_cached0 方 法 , 判断 指定 的 模板 是 否 存在 缓存 ， 
如 果 存 在 则 直接 执行 缓存 中 的 文件 , 否则 执行 动态 获取 数据 和 输出 的 操作 。 操作 代码 如 下 : 
$smarty->caching=true; /开启 缓存 
if(!$smarty->is_cached('index.html")){ 
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S$array_id[]=$array[$i][id]; 
S$array_name[]=$array[$i][name]l: 


} 

S$smarty->assign('cust_id', Sarray id): /设置 下 拉 列表 的 值 
$smarty->assign('cust_name', $array_name): /设置 列表 的 显示 数据 

} 

$array= explode('', mt rand(1000,9999)): // 生 成 随机 验证 码 
$smarty->assign('title',' 开 启 网 站 注册 页 面 的 缓存 "); // 将 指定 数据 赋 给 模板 变量 
$smarty->assign('content', $array): // 将 数组 赋 给 模板 变量 
$smarty->assign('contents',$arrays); // 将 数组 赋 给 模板 变量 
$smarty->display('index.html’); // 指 定 模板 页 

> 


缓存 文件 存储 在 system\Smarty\cache 目录 下 ， 而 存储 路 径 的 设置 是 在 system\system. 


| smartyinc php 文件 中 完成 。 有 关 用 户 注册 的 其 他 功能 ， 请 读者 参考 配套 资源 中 的 源 程序 ， 
| 这 里 不 再 獒 述 。 


| 技术 要 点 


缓存 的 设置 ， 既 要 考虑 网 站 访问 速度 的 提高 ， 又 要 考虑 缓存 生命 周期 的 合理 性 。 不 能 


偏执 一 方 ， 应 该 采取 中 庸 之 道 ， 达 到 一 个 最 理想 的 效果 。 


例如 ， 网 站 首页 是 不 需要 经 常 更 新 的 内 容 ， 缓 存 的 生存 周期 就 可 以 设置 长 一 些 ， 而 类 
似 于 论坛 中 帖子 的 数据 ， 则 可 以 不 开启 缓存 ， 因 为 帖子 的 数据 会 不 断 更 新 ， 就 没有 必要 再 
使 用 缓存 ， 如 果 使 用 缓存 可 能 会 导致 浏览 不 到 最 新 的 数据 。 
(1) 开启 缓存 。 
开启 缓存 的 方法 非常 简单 ， 只 要 将 Smarty 对 象 中 $config 的 值 设置 为 true 即 可 ， 同 时 
还 要 通过 Smarty 对 象 中 的 $cache_dir 属性 指定 缓存 文件 的 存储 位 置 。 其 操作 代码 如 下 : 
S$smarty->caching=true; /开启 缓存 
$smarty->cache_dir =BASE PATH .SMARTY _ PATH.cache/: /定义 缓存 文件 存储 位 置 
(2) 设置 缓存 生命 周期 。 
缓存 创建 成 功 后 ， 必 须 为 它 设置 一 个 生命 周期 ， 如 果 它 一 直 不 更 新 ， 那 么 就 没有 任何 
意义 。 设 置 缓存 生命 周期 应 用 的 是 Smarty 对 象 中 的 Scache_lifetime 属性 ， 缓 存 时 间 以 秒 为 
单位 ， 默 认 值 是 3600 秒 。 其 操作 代码 如 下 : 


$smarty->cachine=true; /开启 缓存 
$smarty->cache dir= BASE PATH .SMARTY PATH.cache/: /定义 缓存 文件 存储 位 置 
$smarty->cache lifetime=3600 // 设 置 缓存 时 间 为 1 小 时 


(3) 判断 模板 文件 是 否 已 经 被 缓存 。 
如 果 页 面 已 经 被 缓存 ， 那 么 就 可 以 直接 调用 缓存 文件 ， 而 不 再 执行 动态 获取 数据 和 输 
出 的 操作 。 为 了 避免 在 开启 缓存 后 ， 再 次 执行 动态 获取 数据 和 输出 操作 给 服务 器 带 来 的 压 
力 , 最 佳 的 方法 就 是 应 用 Smarty 对 象 中 的 is_cached0 方 法 , 判断 指定 的 模板 是 否 存在 缓存 ， 
如 果 存 在 则 直接 执行 缓存 中 的 文件 , 否则 执行 动态 获取 数据 和 输出 的 操作 。 操作 代码 如 下 : 
$smarty->caching=true; /开启 缓存 
if(!$smarty->is_cached('index.html")){ 
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// 执 行动 态 获取 数据 和 输出 的 操作 
} 
$smarty->display('index.html"); 
(4) 清除 模板 中 缓存 。 
缓存 的 清除 有 两 种 方法 : 
第 一 种 是 clear_all_cache0 方 法 ， 清 除 所 有 模板 缓存 。 其 语法 如 下 : 
void clear all_cache (int expire time) | 
可 选 参数 expire time， 可 以 指定 一 个 以 秒 为 单位 的 最 小 时 间 ， 超 过 这 个 时 间 的 缓存 都 | 
将 被 清除 。 | 
第 二 种 是 clear_cache0 方 法 ， 清 除 指定 模板 的 缓存 。 其 语法 如 下 : 
void clear_cache (string template [, string cache id [, string compile id [, int expire time]]]) | 
如 果 这 个 模板 有 多 个 缓存 ， 可 以 用 第 二 个 参数 指定 要 清除 缓存 的 缓存 号 ， 还 可 以 通过 | 
第 三 个 参数 指定 编译 号 。 可 以 把 模板 分 组 ， 以 便 可 以 方便 地 清除 一 组 缓存 。 第 四 个 参数 是 | 
可 选 的 ， 用 来 指定 超过 某 一 时 间 以 秒 为 单位 的 缓存 才 会 被 清除 。 | 


实例 247 通过 配置 文件 定义 变量 


( 实例 位 置 : 配套 资源 \SL\14\247 ) 


实例 说 明 


配置 文件 的 应 用 ， 有 利于 设计 者 管理 文件 中 的 模板 全 局 变量 。 例 如 ， 定 义 一 个 模板 
彩 变量 。 一 般 情况 下 如 果 想 改变 一 个 程序 的 外 观 色彩 ， 必 须 更 改 每 一 个 文件 的 颜色 变量 。 | 
如 果 有 配置 文件 ， 色 彩 变量 就 可 以 保存 在 一 个 单独 的 文件 中 ， 只 要 改变 配置 文件 就 可 以 实 | 
现 色彩 的 更 新 ， 这 与 在 Web 页 面 开 发 中 应 用 的 CSS 样式 非常 相似 。 在 本 实例 中 将 讲解 如 | 
何 应 用 Smarty 中 的 配置 文件 ， 并 通过 配置 文件 定义 页 面 中 body 标签 的 样式 ， 其 运行 结果 | 
如 图 14.8 所 示 。 | 
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实现 过 程 


具体 步骤 如 下 : | 
(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 全 存 朋 和 本文 伯 
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// 执 行动 态 获取 数据 和 输出 的 操作 
} 
$smarty->display('index.html"); 
(4) 清除 模板 中 缓存 。 
缓存 的 清除 有 两 种 方法 : 
第 一 种 是 clear_all_cache0 方 法 ， 清 除 所 有 模板 缓存 。 其 语法 如 下 : 
void clear all_cache (int expire time) | 
可 选 参数 expire time， 可 以 指定 一 个 以 秒 为 单位 的 最 小 时 间 ， 超 过 这 个 时 间 的 缓存 都 | 
将 被 清除 。 | 
第 二 种 是 clear_cache0 方 法 ， 清 除 指定 模板 的 缓存 。 其 语法 如 下 : 
void clear_cache (string template [, string cache id [, string compile id [, int expire time]]]) | 
如 果 这 个 模板 有 多 个 缓存 ， 可 以 用 第 二 个 参数 指定 要 清除 缓存 的 缓存 号 ， 还 可 以 通过 | 
第 三 个 参数 指定 编译 号 。 可 以 把 模板 分 组 ， 以 便 可 以 方便 地 清除 一 组 缓存 。 第 四 个 参数 是 | 
可 选 的 ， 用 来 指定 超过 某 一 时 间 以 秒 为 单位 的 缓存 才 会 被 清除 。 | 


实例 247 通过 配置 文件 定义 变量 


( 实例 位 置 : 配套 资源 \SL\14\247 ) 


实例 说 明 


配置 文件 的 应 用 ， 有 利于 设计 者 管理 文件 中 的 模板 全 局 变量 。 例 如 ， 定 义 一 个 模板 
彩 变量 。 一 般 情况 下 如 果 想 改变 一 个 程序 的 外 观 色彩 ， 必 须 更 改 每 一 个 文件 的 颜色 变量 。 | 
如 果 有 配置 文件 ， 色 彩 变量 就 可 以 保存 在 一 个 单独 的 文件 中 ， 只 要 改变 配置 文件 就 可 以 实 | 
现 色彩 的 更 新 ， 这 与 在 Web 页 面 开 发 中 应 用 的 CSS 样式 非常 相似 。 在 本 实例 中 将 讲解 如 | 
何 应 用 Smarty 中 的 配置 文件 ， 并 通过 配置 文件 定义 页 面 中 body 标签 的 样式 ， 其 运行 结果 | 
如 图 14.8 所 示 。 | 
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图 14.8 通过 配置 文件 定义 变量 
实现 过 程 


具体 步骤 如 下 : | 
(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 全 存 朋 和 本文 伯 
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目录 ; 创建 类 文件 system.smarty.inc.php， 定 义 Smarty 的 配置 类 ， 在 该 类 中 指定 配置 文件 

存储 的 目录 ， 定 义 类 的 实例 化 文件 system.inc php， 完 成 Smarty 类 的 实例 化 操作 ， 并 返回 

操作 对 象 。 
(2) 创建 mdex.php 文件 , 载 入 类 的 实例 化 文件 ; 通过 文件 系统 函数 file_get_contents() 

读 取 文 本 文件 中 的 数据 ， 并 且 将 数据 存储 到 模板 变量 中 ， 最 终 指 定 模 板 页 。 其 代码 如 下 : 


<2php 
header ( "Content-type: text/htmil; charset=UTF-8" ); // 设 置 文件 编码 格式 


include("system/system.inc.php"); // 包 含 配置 文件 

$str = file_get_contents('files/content.txt"); // 读 取 文本 文件 中 的 数据 
$smarty->assign('content,,iconv("gb2312","utf-8",$str));// 将 文本 文件 中 的 数据 存储 到 模板 变量 中 
$smarty->display(index.html): /指定 模板 页 

?> 


(3) 创建 mdex.html 模板 页 。 首 先 ， 通 过 config load0 函 数 加 载 配置 文件 。 然后， 应 


用 “#” 和 $smarty.config 引用 配置 文件 中 的 变量 。 最 后 ， 通 过 模板 变量 输出 文本 文件 中 的 
| 数据 。 其 关键 代码 如 下 : 


{ config load file="file con.conf"} {* 加 载 配置 文件 *} 
<title> {#title#} </title> 
<body leftmargin="{#leftmargin#}" topmargin="{#topmargin#}" marginwidth="{#marginwidth#}" 


marginheight=" {#marginheight#}"> 


<td height="228" colspan="2" align="left" valign="top" class=" {$smarty.config.styles}"> {$content} </td> 


| 技术 要 点 


(1) 创建 配置 文件 。 
配置 文件 可 以 任意 命名 ,其 存储 位 置 由 Smarty 对 象 的 Sconfig dir 属性 指定 。 如 果 存 在 


不 只 在 一 个 区 域内 使 用 的 变量 值 ， 可 以 使 用 三 引号 〈""") 将 它 完整 地 封装 起 来 。 在 创建 配 
| 置 文件 时 ， 建 议 在 程序 运行 前 使 用 “#” 加 一 些 注释 信息 ， 这 样 有 助 于 程序 的 阅读 、 更 新 。 


在 配置 文件 中 既 可 以 声明 全 局 变量 ， 也 可 以 声明 局 部 变量 。 如 果 声 明 局 部 变量 ， 可 以 


使 用 中 括号 “ 口 ” 括 起 来 ， 在 中 括号 之 内 声明 的 变量 属于 局 部 变量 ， 而 中 括号 之 外 声明 的 
| 变量 都 是 全 局 变量 。 中 括号 的 使 用 不 仅 使 配置 文件 中 声明 变量 的 模块 变 得 清晰 ， 而 且 可 以 


在 模板 中 选择 加 载 中 括号 内 的 变量 。 
(2) 加 载 配置 文件 。 
加 载 配置 文件 应 用 Smarty 的 内 建 函 数 config load0， 其 语法 如 下 : 


{config load file="file name " section="add attribute" scope="" global=""} 


参数 说 明 : 

file: 指定 包含 的 配置 文件 的 名 称 。 

回 。 section: 附加 属性 ， 当 配置 文件 中 包含 多 个 部 分 时 应 用 ， 指 定 具体 从 哪 一 部 分 中 
取得 变量 。 

scope: 加 载 数 据 的 作用 域 ， 取 值 必须 为 local、parent 或 global。local 说 明 该 变量 
的 作用 域 为 当前 模板 ;，parent 说 明 该 变量 的 作用 域 为 当前 模板 和 当前 模板 的 父 模 
板 〈 调 用 当前 模板 的 模板 ) ; global 说 明 该 变量 的 作用 域 为 所 有 模板 。 

. 398 . 
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global: 说 明 加 载 的 变量 是 否 全 局 可 见 ， 等 同 于 scope=parent。 


脚下 留神 : ! 
当 指 定 scope 属性 时 ， 可 以 设置 global 属性 ， 但 模板 忽略 该 属性 值 ， 而 以 scope 属 ， 纤 | 
为 准 。 


(3) 引用 配置 文件 中 的 变量 。 | 
配置 文件 加 载 成 功 后 ， 就 可 以 在 模板 中 引用 配置 文件 中 声明 的 变量 。 引 用 配置 文件 应 | 
用 的 是 “#” 或 者 Smarty 的 保留 变量 $smarty.config。 其 应 用 示例 如 下 : | 


{ config load file="file con.conf"} 从 加 载 配置 文件 *} 
{#title#} 
<td height="228" colspan="2" align="left" valign="top" class="{$smarty.config.styles} "> 


实例 248 Smarty+ADODB 完成 数据 的 分 页 显示 


( 实例 位 置 : 配套 资源 \SL\14\248 视频 位 置 : 配套 资源 \SP\14\248 ) 


实例 说 明 


本 实例 将 介绍 通过 面向 对 象 的 方法 完成 Smarty 的 配置 ，ADODB 连接 MySQL、 操 作 
MySQL 数据 库 以 及 分 页 Wn ， 其 运行 结果 如 图 14.9 所 示 。 | 


图 14.9 Smarty+ADODB 完成 数据 的 分 页 显示 


实现 过 程 
具体 步骤 如 下 : | 
(1) 创建 system 文件 夹 ， 存储 ADODB 类 库 和 Smarty 模板 文件 。 创建 system.smarty.inc. | 
php 文件 ， 定 义 连接 数据 库 、 操 作 数 据 库 和 分 页 类 。 | 
数据 库 连接 类 ConnDB， 定 义 构造 方法 ConnDB 为 成 员 变量 赋值 ， 定 义 GetConnId 方 | 
法 ， 应 用 NewADOConnection0) 函 数 连接 MySQL、mssql 或 者 Access 数据 库 ， 设置 数据 库 编 | | 
码 格式 为 UTF-8, 最 后 返回 数据 库 连接 对 象 ; 定义 CloseConntd 方法 ， 关 闭 与 数据 库 的 连接 。 | 
数据 库 操作 类 AdminDB, 定义 ExecSQL() 方 法 完成 对 数据 库 添 加 更 新 和 删除 的 操作 。 | 
* 399， ke 


第 ] 4 章 ,Smarty 模板 § 


global: 说 明 加 载 的 变量 是 否 全 局 可 见 ， 等 同 于 scope=parent。 


脚下 留神 : ! 
当 指 定 scope 属性 时 ， 可 以 设置 global 属性 ， 但 模板 忽略 该 属性 值 ， 而 以 scope 属 ， 纤 | 
为 准 。 


(3) 引用 配置 文件 中 的 变量 。 | 
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用 的 是 “#” 或 者 Smarty 的 保留 变量 $smarty.config。 其 应 用 示例 如 下 : | 


{ config load file="file con.conf"} 从 加 载 配置 文件 *} 
{#title#} 
<td height="228" colspan="2" align="left" valign="top" class="{$smarty.config.styles} "> 


实例 248 Smarty+ADODB 完成 数据 的 分 页 显示 


( 实例 位 置 : 配套 资源 \SL\14\248 视频 位 置 : 配套 资源 \SP\14\248 ) 


实例 说 明 


本 实例 将 介绍 通过 面向 对 象 的 方法 完成 Smarty 的 配置 ，ADODB 连接 MySQL、 操 作 
MySQL 数据 库 以 及 分 页 Wn ， 其 运行 结果 如 图 14.9 所 示 。 | 


图 14.9 Smarty+ADODB 完成 数据 的 分 页 显示 


实现 过 程 
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(1) 创建 system 文件 夹 ， 存储 ADODB 类 库 和 Smarty 模板 文件 。 创建 system.smarty.inc. | 
php 文件 ， 定 义 连接 数据 库 、 操 作 数 据 库 和 分 页 类 。 | 
数据 库 连接 类 ConnDB， 定 义 构造 方法 ConnDB 为 成 员 变量 赋值 ， 定 义 GetConnId 方 | 
法 ， 应 用 NewADOConnection0) 函 数 连接 MySQL、mssql 或 者 Access 数据 库 ， 设置 数据 库 编 | | 
码 格式 为 UTF-8, 最 后 返回 数据 库 连接 对 象 ; 定义 CloseConntd 方法 ， 关 闭 与 数据 库 的 连接 。 | 
数据 库 操作 类 AdminDB, 定义 ExecSQL() 方 法 完成 对 数据 库 添 加 更 新 和 删除 的 操作 。 | 
* 399， ke 
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首先 ， 通 过 substr0 函 数 截 取 SQL 语句 中 前 6 个 字符 串 ， 并 将 截取 的 字符 串 转 换 成 小 写 。 
然后 , 通过 Execute() 函 数 执行 SQL 语句 。 最 后 , 根据 截取 的 字符 串 判 断 SQL 语句 的 类 型 ， 
如 果 是 select 查询 语句 ， 则 执行 GetRows0 函 数 ， 如 果 查 询 结 果 为 0， 则 返回 false， 否 则 返 
回 查 询 的 数组 ;， 如果 SQL 语句 为 update、insert 或 者 delete 类 型 ， 执 行 成 功 则 返回 true， 
否则 返回 false。 

分 页 类 SepPage， 定 义 ShowDate(0 方 法 完成 从 数据 库 中 读 取 数据 的 操作 ， 执 行 
PageExecute() 函 数 实现 分 页 功能 ， 并 且 将 返回 值 定义 到 数组 中 ; 定义 ShowPage() 方 法 根据 


| 查询 结果 ， 应 用 分 页 函数 创建 分 页 超 链接 ， 并 且 将 返回 结果 定义 到 变量 gstr 中 。 


Smarty 配置 类 SmartyProject， 继 承 Smarty 类 库 中 Smarty 类 ， 设 置 本 实例 中 Smarty 


缓存 文件 、 配 置 文件 、 模 板 文件 和 编译 文件 的 存储 位 置 。 


system.smarty.inc.php 文件 的 代码 请 参考 本 书 配套 资源 ， 由 于 篇 幅 所 限 这 里 不 再 介绍 。 
(2) 创建 system.inc.php 文件 ， 完 成 对 数据 库 连接 、 操 作 、 分 页 以 及 Smarty 配置 类 


| 的 实例 化 操作 ， 其 代码 如 下 ， 


<?php 

require("system.smarty.inc.php"): // 包 含 配置 类 文件 

$smarty=new SmartyProjectO; // 实 例 化 配置 类 
| $connobj=new ConnDB("mysql","localhost","root","111","db_database14",false); /数据 库 连 接 类 实 
| 例 化 
| $conn=$connobj->GetConnId(); 

$admindb=new AdminDB(): /数据 库 操作 类 实例 化 

$seppage=new SepPage():; // 分 页 类 实例 化 

> 


到 此 ， 有 关 ADODB 和 Smarty 的 安装 和 配置 介绍 完毕 。 
(3) 创建 index.php 文件 ， 调 用 分 页 类 中 的 ShowDate0 方 法 ， 分 页 读 取 数 据 库 中 的 数 


据 ， 并 且 将 返回 值 赋 给 模板 变量 ; 调用 分 页 类 中 的 ShowPage0 方 法 ， 完 成 分 页 超 链 接 的 输 


出 ， 同 样 将 返回 值 赋 给 模板 变量 ， 最 后 指定 模板 页 。 其 代码 如 下 : 
<2php 
require_once("systemy/system.inc.php"); /包含 配置 文件 
$arraybbs=$seppage->ShowDate("select * from tb_commo where isnew = 1 order by id ",$conn,3,$_ 
GET["page")]); // 调 用 分 页 类 ， 实 现 分 页 功能 
if(!$arraybbs){ 
$smarty->assign("isbbs","F"); 
}else{ 
$smarty->assign("isbbs","T"); 
$smarty->assign("showpage",$seppage->ShowPage(" 商 品 "," 个 ","","a1")); /定义 输出 分 页 数据 的 
模板 变量 showpage 
$smarty->assign("arr",$arraybbs); 


} 
$smarty->assign('title''Smarty+Adodb 完成 数据 分 页 显示 
$smarty->display(index.html'): 
Rs 


(4) 创建 mdex.html 模板 文件 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 。 
400. 
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缓存 文件 、 配 置 文件 、 模 板 文件 和 编译 文件 的 存储 位 置 。 


system.smarty.inc.php 文件 的 代码 请 参考 本 书 配套 资源 ， 由 于 篇 幅 所 限 这 里 不 再 介绍 。 
(2) 创建 system.inc.php 文件 ， 完 成 对 数据 库 连接 、 操 作 、 分 页 以 及 Smarty 配置 类 


| 的 实例 化 操作 ， 其 代码 如 下 ， 


<?php 

require("system.smarty.inc.php"): // 包 含 配置 类 文件 

$smarty=new SmartyProjectO; // 实 例 化 配置 类 
| $connobj=new ConnDB("mysql","localhost","root","111","db_database14",false); /数据 库 连 接 类 实 
| 例 化 
| $conn=$connobj->GetConnId(); 

$admindb=new AdminDB(): /数据 库 操作 类 实例 化 

$seppage=new SepPage():; // 分 页 类 实例 化 
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到 此 ， 有 关 ADODB 和 Smarty 的 安装 和 配置 介绍 完毕 。 
(3) 创建 index.php 文件 ， 调 用 分 页 类 中 的 ShowDate0 方 法 ， 分 页 读 取 数 据 库 中 的 数 


据 ， 并 且 将 返回 值 赋 给 模板 变量 ; 调用 分 页 类 中 的 ShowPage0 方 法 ， 完 成 分 页 超 链 接 的 输 


出 ， 同 样 将 返回 值 赋 给 模板 变量 ， 最 后 指定 模板 页 。 其 代码 如 下 : 
<2php 
require_once("systemy/system.inc.php"); /包含 配置 文件 
$arraybbs=$seppage->ShowDate("select * from tb_commo where isnew = 1 order by id ",$conn,3,$_ 
GET["page")]); // 调 用 分 页 类 ， 实 现 分 页 功能 
if(!$arraybbs){ 
$smarty->assign("isbbs","F"); 
}else{ 
$smarty->assign("isbbs","T"); 
$smarty->assign("showpage",$seppage->ShowPage(" 商 品 "," 个 ","","a1")); /定义 输出 分 页 数据 的 
模板 变量 showpage 
$smarty->assign("arr",$arraybbs); 


} 
$smarty->assign('title''Smarty+Adodb 完成 数据 分 页 显示 
$smarty->display(index.html'): 
Rs 


(4) 创建 mdex.html 模板 文件 ， 应 用 section 语句 和 模板 变量 完成 数据 的 分 页 输出 。 
400. 
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(5) 创建 showcommo.html 和 showcommo php 文件， 用 于 输出 指定 产品 的 详细 信息 。 | 
技术 要 点 | 


Smarty+ADODB 完成 数据 的 分 页 显示 ， 其 中 涵盖 了 ADODB 连接 MySQL、ADODB 会 内 
操作 MySQL 数据 库 以 及 ADODB 中 的 分 页 技术 ,而 Smarty 依旧 是 将 ADODB 操作 MySQL | ”一 一 
获取 到 的 数据 通过 assign 方法 传递 给 模板 变量 ,然后 在 模板 页 中 应 用 section 语句 循环 输出 国 2 2 
数据 。 | 

其 中 有 关 ADODB 连接 、 操 作 MySQL 数据 库 以 及 ADODB 中 分 页 技术 的 详细 讲解 读 | 
者 可 以 参考 ADODB 的 相关 资料 ， 由 于 不 是 本 实例 要 着 重 讲解 的 部 分 ， 故 这 里 不 再 袭 述 。 | 

在 本 实例 中 将 Smarty 的 配置 方法 以 及 ADODB 连接 和 操作 数据 库 的 方法 都 存储 
system.smarty.inc.php 文件 中 ; 将 Smarty 配置 类 、 数 据 库 的 连接 和 操作 类 的 实例 化 存储 在 
system.inc.php 文件 中 ; 将 Smarty 的 编译 文件 、 配 置 文件 和 缓存 文件 的 存储 目录 放置 在 
Smarty 文件 夹 下 ; 而 Smarty 类 库 和 ADODB5 类 库 则 存储 在 与 实例 根 目录 的 同 级 目录 下 ， 
本 实例 的 文件 夹 架 构 如 图 14.10 所 示 。 


Mt 


加 14 章 文件 夹 
D0 一 一 一 一 一 一 一 一 一 一 一 一 实例 要 文件 夫 
[= 
由 - 回 inages 
回 js 
回 pics 
日 - 回 systen 
日 加 Sarty 一 一 一 一 一 一 一 一 Searty 读 取 文 件 夫 
局 ”cache 一 一 一 一 一 一 一 一 一 狠 存 文件 夹 
局 configs 一 一 一 一 一 一 一 一 配置 文件 夹 
由 - 回 tenplates_c 一 一 一 一 一 一 编译 文件 文件 夫 
司 ”syste ine php 一 一 一 一 一 一 一 类 的 实例 化 文件 
二 systen. snarty. ine. php Smar ty 模板 配置 类 封装 
司 index htnl 一 一 一 一 一 一 一 一 一 模板 文件 
于 index pp 一 一 一 一 一 一 一 一 一 动态 PP 文件 
十 :howconno htnl 
二 showconno. php 
名 adodt5 AD0DB 类 库 文件 夫 
忆 at 一 数据 库 文件 存储 文件 夫 
外 libs Smarty 类 库 文 件 夫 


图 14.10 ”本 实例 的 文件 夹 架构 


实例 249 ”Smarty 模板 中 truncate0) 方 法 截取 字符 串 
( 实例 位 置 : 配套 资源 \SL\14\249 ) 
实例 说 


在 Smarty 中 ， 提 供 truncate0 方 法 对 字符 串 进行 截取 ， 该 方法 会 截取 到 一 个 词 的 末尾 。 
在 本 实例 中 ,应 用 truncate0 方 法 对 论坛 中 标题 和 内 容 进行 截取 ， 并 且 应 用 省 咯 号 蔡 换 蕉 取 | 
的 内 容 ， 运 行 结果 如 图 14.11 所 示 。 
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(5) 创建 showcommo.html 和 showcommo php 文件， 用 于 输出 指定 产品 的 详细 信息 。 | 
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获取 到 的 数据 通过 assign 方法 传递 给 模板 变量 ,然后 在 模板 页 中 应 用 section 语句 循环 输出 国 2 2 
数据 。 | 
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本 实例 的 文件 夹 架 构 如 图 14.10 所 示 。 
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实例 249 ”Smarty 模板 中 truncate0) 方 法 截取 字符 串 
( 实例 位 置 : 配套 资源 \SL\14\249 ) 
实例 说 


在 Smarty 中 ， 提 供 truncate0 方 法 对 字符 串 进行 截取 ， 该 方法 会 截取 到 一 个 词 的 末尾 。 
在 本 实例 中 ,应 用 truncate0 方 法 对 论坛 中 标题 和 内 容 进行 截取 ， 并 且 应 用 省 咯 号 蔡 换 蕉 取 | 
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图 14.11 Smarty 模板 中 truncate 方法 截取 字符 串 
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| 实现 过 程 


具体 步骤 如 下 : 
(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 缓 存 目录 ; 创建 类 文 


件 system.smartyincphp， 定 义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实 
| 例 化 文件 system.inc.php， 完 成 各 个 类 的 实例 化 操作 ， 并 返回 操作 对 象 。 


(2) 创建 index.php 文件 , 载 入 类 的 实例 化 文件 ; 分 页 读 取 数据 库 中 存储 的 论坛 数据 ， 


并 且 将 读 取 的 结果 存储 到 模板 变量 中 ， 最 终 指定 模板 页 。 其 代码 如 下 : 


<2?php 
Tequire_once("systemy/system_inc.php"); /调用 指定 的 文件 
$array=$seppage->ShowDate("select * from tb_guestbook order by id desc",$conn,6,$_GET["page'"]); 
/调用 分 页 类 ， 实 现 分 页 
if(!$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执行 失败 则 输出 模板 变量 iscommo 的 值 为 F 
jelse{ 
$smarty->assign("iscommo","T"):; // 判 断 如 果 执 行 成 功 , 则 输出 模板 变量 iscommo 的 值 为 T， 
$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "," 条 ",","a1")); // 定 义 输出 分 页 数据 的 
模板 变量 showpage 


$smarty->assign("array", $array); 
} 
$smarty->assign('title','truncate 方法 截取 字符 串 "); // 定 义 标题 
$smarty->display('index.html'); /指定 模板 页 
es 


(3) 创建 index.html 模板 页 ， 获 取 模板 变量 传递 的 数据 ， 实 现 数据 的 分 页 和 输出， 并且 
通过 truncate 方法 对 输出 的 标题 和 内 容 进 行 截取 操作 ， 标 题 截取 30 个 字 节 ， 内 容 截 取 60 
个 字 节 ， 应 用 省 略 号 补 齐 截取 部 分 。 其 关键 代码 如 下 : 


{section name=id loop=$array} 

<tr> 

<td> 

{$array[id].id} {$array[id].titleltruncate:30:"...":false}:; 

积分 : {$array[id].integral} 

时 间 : {$array[id].createtimeltruncate:12:""}<br> 
{$array[id].contentltruncate:60:"...":false} 


</td> 
</t> 
{/section} 
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truncate 方法 , 从 字符 串 开 始 处 截取 指定 长 度 的 字符 , 默认 是 80 个 字符 。 应 用 示例 如 下 : | 
{$articleTitleltruncate} <!-- 截 取 默 认 长 度 的 字符 串 --> | 
{$articleTitleltruncate:30} <!-- 截 取 30 个 字符 --> 
{$articleTitleltruncate:30:""} <!-- 截 取 30 个 字符 ， 结 尾 处 默认 使 用 省 略 号 进行 添加 --> 
{$articleTitleltruncate: sh <!-- 截 取 30 个 字符 ， 结 尾 处 以 “---” 进 行 添加 --> 
{$articleTitleltruncate: true} <!-- 截 取 30 个 字符 串 ， 进 行 精确 截取 --> 
{$articleTitleltruncate:30:"...":true} <!-- 精 确 截 取 30 个 字符 ， 以 省 略 号 进行 添加 --> 


其 中 $articleTitle 为 模板 变量 。truncate() 方 法 的 参数 说 明 如 表 14.3 所 示 。 
表 14.3 truncate() 方 法 的 参数 说 明 


参数 说 了 明 
YL 第 一 个 参数 ， 指 定 截取 字符 的 数量 ， 类 型 为 Integer 
2 第 二 个 参数 ， 指 定 截取 后 追加 在 截取 词 后 面 的 字符 串 ， 类 型 为 String 
第 三 个 参数 , 类 型 为 Boolean, 如 果 该 值 为 false, 表示 截取 到 词 的 边界 ; 如 果 该 值 为 tue， 


表示 截取 时 精确 到 指定 字符 


实例 230 Register_ function() 方 法 注册 模板 函数 


( 实例 位 置 : 配套 资源 \SL\14\250 ) 


实例 说 明 | 
本 实例 讲解 在 Smarty 中 注册 模板 函数 的 方法 ， 模 板 函 数 可 以 实现 与 PHP 中 自 定义 函 | 
数 相同 的 功能 ， 其 特点 是 模板 函数 的 注册 在 动态 页 中 完成 ， 实 际 的 应 用 在 静态 页 中 进行 ， | 
完全 体现 Smarty 的 动静 分 离 的 开发 模式 。 在 本 实例 分 页 输出 论坛 帖子 的 信息 ， 并 通过 注 | | 
册 模 板 函 数 对 帖子 的 内 容 进行 截取 ， 如 果 帖 子 内 容 超出 指定 的 长 度 就 对 其 进行 截取 ， 并 且 | 

使 用 省 略 号 替代 被 截取 部 分 ， 运 行 结果 如 图 14.12 所 示 。 | 


FANXING wns eres /wn om 


首页 1 注册 1 登录 1 论坛 


NN 于 名 图 片 净 件 去 
“性 
S Ey 
三 名 联系 方式 
2 en 
33 本 外 电子 图 节 
与 全 Ty Sir 


由于 4 条 二 由 时 示 6 条 第 1 页 其 1 由 到! 一 看 


二 FE 六 程 词 各 可 世 。 积分 ; s5 时 
各 位 议 者 :和 反 ,首先 吕 央 多 一 站 以 来 对 和 


图 14.12 Register function0 方 法 注册 模板 函数 
实现 过 程 


具体 步骤 如 下 : | 
(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 缓 存 目录 ; 创建 类 文 
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truncate 方法 , 从 字符 串 开 始 处 截取 指定 长 度 的 字符 , 默认 是 80 个 字符 。 应 用 示例 如 下 : | 
{$articleTitleltruncate} <!-- 截 取 默 认 长 度 的 字符 串 --> | 
{$articleTitleltruncate:30} <!-- 截 取 30 个 字符 --> 
{$articleTitleltruncate:30:""} <!-- 截 取 30 个 字符 ， 结 尾 处 默认 使 用 省 略 号 进行 添加 --> 
{$articleTitleltruncate: sh <!-- 截 取 30 个 字符 ， 结 尾 处 以 “---” 进 行 添加 --> 
{$articleTitleltruncate: true} <!-- 截 取 30 个 字符 串 ， 进 行 精确 截取 --> 
{$articleTitleltruncate:30:"...":true} <!-- 精 确 截 取 30 个 字符 ， 以 省 略 号 进行 添加 --> 


其 中 $articleTitle 为 模板 变量 。truncate() 方 法 的 参数 说 明 如 表 14.3 所 示 。 
表 14.3 truncate() 方 法 的 参数 说 明 


参数 说 了 明 
YL 第 一 个 参数 ， 指 定 截取 字符 的 数量 ， 类 型 为 Integer 
2 第 二 个 参数 ， 指 定 截取 后 追加 在 截取 词 后 面 的 字符 串 ， 类 型 为 String 
第 三 个 参数 , 类 型 为 Boolean, 如 果 该 值 为 false, 表示 截取 到 词 的 边界 ; 如 果 该 值 为 tue， 


表示 截取 时 精确 到 指定 字符 


实例 230 Register_ function() 方 法 注册 模板 函数 


( 实例 位 置 : 配套 资源 \SL\14\250 ) 


实例 说 明 | 
本 实例 讲解 在 Smarty 中 注册 模板 函数 的 方法 ， 模 板 函 数 可 以 实现 与 PHP 中 自 定义 函 | 
数 相同 的 功能 ， 其 特点 是 模板 函数 的 注册 在 动态 页 中 完成 ， 实 际 的 应 用 在 静态 页 中 进行 ， | 
完全 体现 Smarty 的 动静 分 离 的 开发 模式 。 在 本 实例 分 页 输出 论坛 帖子 的 信息 ， 并 通过 注 | | 
册 模 板 函 数 对 帖子 的 内 容 进行 截取 ， 如 果 帖 子 内 容 超出 指定 的 长 度 就 对 其 进行 截取 ， 并 且 | 

使 用 省 略 号 替代 被 截取 部 分 ， 运 行 结果 如 图 14.12 所 示 。 | 


FANXING wns eres /wn om 


首页 1 注册 1 登录 1 论坛 


NN 于 名 图 片 净 件 去 
“性 
S Ey 
三 名 联系 方式 
2 en 
33 本 外 电子 图 节 
与 全 Ty Sir 


由于 4 条 二 由 时 示 6 条 第 1 页 其 1 由 到! 一 看 


二 FE 六 程 词 各 可 世 。 积分 ; s5 时 
各 位 议 者 :和 反 ,首先 吕 央 多 一 站 以 来 对 和 


图 14.12 Register function0 方 法 注册 模板 函数 
实现 过 程 


具体 步骤 如 下 : | 
(1) 创建 system 文件 夹 ， 定 义 Smarty 文件 夹 ， 存 储 编译 目录 、 缓 存 目录 ; 创建 类 文 
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CT 
2 
件 system.smartyincphp， 定 义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实 
例 化 文件 system.incphp， 完 成 各 个 类 的 实例 化 操作 ， 并 返回 操作 对 象 。 

(2) 创建 mdex.php 文件 ， 载 入 类 的 实例 化 文件 ; 编写 自 定义 函数 unHtml， 对 论坛 中 
的 内 容 进 行 截取 操作 ; 应 用 register_function 注册 模板 函数 ; 分 页 读 取 数 据 库 中 存储 的 论坛 
数据 ， 并 且 将 读 取 的 结果 存储 到 模板 变量 中 ， 最 终 指 定 模板 页 。 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html:; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once("system/system.inc.php"); /调用 指定 的 文件 
function unHtml($params) { // 创 建 模板 函数 
extract($params); // 读 取 数 据 
if(strlen($text)>40){ 
$str=mb_substr($text,0,40,"utf-8")."..."; // 截 取 字 符 串 
}else{ 
$str=$text; 
E 
return $str; /返回 截取 结果 
1 
$smarty->register function("Util", "unHtml"); // 注 册 模 板 函 数 


$array=$seppage->ShowDate("select * from tb_guestbook order by id desc",$conn,6,$_GET["page"]); 
// 调 用 分 页 类 ， 实 现 分 页 
if(!$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执 行 失败 则 输出 模板 变量 iscommo 的 值 为 F 
}else{ 
$smarty->assign("iscommo","T"); /判断 如 果 执 行 成 功 , 则 输出 模板 变量 iscommo 的 值 为 
$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "," 条 ",","a1")); /定义 输出 分 页 数 
据 的 模板 变量 showpage 
$smarty->assign("array", $array):; 
} 
$smarty->assign('title','register_function0 方 法 注册 模板 函数 '): 
$smarty->display('index.html'); 


?> 


(3) 创建 index.html 模板 页 ， 获 取 模板 变量 传递 的 数据 ， 实 现 数据 的 分 页 输出 ， 并 且 

调用 动态 页 中 注册 的 模板 函数 实现 对 论坛 中 内 容 的 截取 操作 。 其 关键 代码 如 下 : 

{section name=id loop=$array} 

<t> 

<td colspan="4" bgcolor="#FFFFFF">{$array[id].id }&nbsp;&nbsp; {Util text=$array[id].title } 积 分 : 
{$array[id].integral} &nbsp:;&nbsp;&nbsp;&nbsp:; 时 间 : {$array[id].createtime}<br> {Util text=$array[id]. 
content} </td> 

</t> 

{/section} 


技术 要 点 
(1) register function() 方 法 ,动态 注册 模板 函数 插件 ， 其 参数 说 明 如 表 14.4 所 示 。 语 
法 如 下 : 
void register_ function (string name, mixed impl, bool cacheable, array or null cache_attrs) 
"404 。 
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CT 
2 
件 system.smartyincphp， 定 义 数据 库 连 接 、 操 作 、 分 页 和 Smarty 的 配置 类 ， 定 义 类 的 实 
例 化 文件 system.incphp， 完 成 各 个 类 的 实例 化 操作 ， 并 返回 操作 对 象 。 

(2) 创建 mdex.php 文件 ， 载 入 类 的 实例 化 文件 ; 编写 自 定义 函数 unHtml， 对 论坛 中 
的 内 容 进 行 截取 操作 ; 应 用 register_function 注册 模板 函数 ; 分 页 读 取 数 据 库 中 存储 的 论坛 
数据 ， 并 且 将 读 取 的 结果 存储 到 模板 变量 中 ， 最 终 指 定 模板 页 。 其 代码 如 下 : 


<?php 
header ( "Content-type: text/html:; charset=UTF-8" ); // 设 置 文件 编码 格式 
require_once("system/system.inc.php"); /调用 指定 的 文件 
function unHtml($params) { // 创 建 模板 函数 
extract($params); // 读 取 数 据 
if(strlen($text)>40){ 
$str=mb_substr($text,0,40,"utf-8")."..."; // 截 取 字 符 串 
}else{ 
$str=$text; 
E 
return $str; /返回 截取 结果 
1 
$smarty->register function("Util", "unHtml"); // 注 册 模 板 函 数 


$array=$seppage->ShowDate("select * from tb_guestbook order by id desc",$conn,6,$_GET["page"]); 
// 调 用 分 页 类 ， 实 现 分 页 
if(!$array){ 
$smarty->assign("iscommo","F"); // 判 断 如 果 执 行 失败 则 输出 模板 变量 iscommo 的 值 为 F 
}else{ 
$smarty->assign("iscommo","T"); /判断 如 果 执 行 成 功 , 则 输出 模板 变量 iscommo 的 值 为 
$smarty->assign("showpage",$seppage->ShowPage(" 帖 子 "," 条 ",","a1")); /定义 输出 分 页 数 
据 的 模板 变量 showpage 
$smarty->assign("array", $array):; 
} 
$smarty->assign('title','register_function0 方 法 注册 模板 函数 '): 
$smarty->display('index.html'); 


?> 


(3) 创建 index.html 模板 页 ， 获 取 模板 变量 传递 的 数据 ， 实 现 数据 的 分 页 输出 ， 并 且 

调用 动态 页 中 注册 的 模板 函数 实现 对 论坛 中 内 容 的 截取 操作 。 其 关键 代码 如 下 : 

{section name=id loop=$array} 

<t> 

<td colspan="4" bgcolor="#FFFFFF">{$array[id].id }&nbsp;&nbsp; {Util text=$array[id].title } 积 分 : 
{$array[id].integral} &nbsp:;&nbsp;&nbsp;&nbsp:; 时 间 : {$array[id].createtime}<br> {Util text=$array[id]. 
content} </td> 

</t> 

{/section} 


技术 要 点 
(1) register function() 方 法 ,动态 注册 模板 函数 插件 ， 其 参数 说 明 如 表 14.4 所 示 。 语 
法 如 下 : 
void register_ function (string name, mixed impl, bool cacheable, array or null cache_attrs) 
"404 。 
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表 14.4 register_function 方法 的 参数 说 明 
参数 说 明 
name 模板 函数 的 名 称 
执行 函数 的 名 称 。 执 行 函数 的 格式 可 以 是 一 个 包含 函数 名 称 的 字符 串 ， 也 可 以 是 一 个 
airay(&$object $method) 数 组 形式 ， 其 中 必 $object 是 一 个 对 象 的 引用 ， 而 $method 是 它 
的 一 个 方法 ;还 可 以 是 一 个 array(&$ class, Smethod) 数 组 形式 ， 其 中 $class 是 一 个 类 的 
名 称 ，$method 是 类 中 的 一 个 方法 
cacheable 可 选 参数 ， 大 多 数 情 况 下 可 以 省 略 
cache attrs 可 选 参数 ， 大 多 数 情 况 下 可 以 省 略 


(2) extract0 函 数 ， 从 数组 中 将 变量 导入 到 当前 的 符号 表 。 语 法 如 下 : 
int extract ( array var_array [, int extract_type [, string prefix]] ) 


本 函数 用 来 将 变量 从 数组 中 导入 到 当前 的 符号 表 中 。 接 受 结合 数组 var_array 作为 参数 
并 将 键 名 当 作 变量 名 , 值 作 为 变量 的 值 。 对 每 个 键 / 值 对 都 会 在 当前 的 符号 表 中 建立 变量 ， 
并 受到 extract_type 和 prefix 参数 的 影响 。 


impl 


指点 迷津 : 
(1) 自 PHP4.0.5 起 本 函数 返回 被 提取 的 交 量 数 据 . (2) EXTR IF _ EXISTS 和 EXTR 


PREFIX IF _ EXISTS 是 PHP4.2.1 中 引进 的 . (3) EXTR REFS 是 PHP4.3.0 中 引进 的 。 


Extract0 检 查 每 个 键 名 看 是 否 可 以 作为 一 个 合法 的 变量 名 ， 同 时 也 检查 和 符号 表 中 已 

有 的 变量 名 的 冲突 。 对 待 非法 数字 和 冲突 的 键 名 的 方法 将 根据 extract_type 参数 决定 。 可 

以 是 以 下 值 之 一 : 

EXTR_OVERWRITE: 如 果 有 冲突 ， 覆 盖 已 有 的 变量 。 

EXTR_SKIP: 如 果 有 冲突 ， 不 覆盖 已 有 的 变量 。 

EXTR_PREFIX_SAME: 如 果 有 冲突 ， 在 变量 名 前 加 上 前 缀 prefix。 

EXTR_PREFIX ALL: 给 所 有 变量 名 加 上 前 绥 prefix。 自 PHP4.0.5 起 这 也 包括 了 

对 数字 索引 的 处 理 。 

EXTR._ PREFIX INVALID: 仅 在 非法 数字 的 变量 名 前 加 上 前 缀 prefix。 本 标记 是 
PHP 4.0.5 新 加 的 。 

回 EXTR IF EXISTS: 仅 在 当前 符号 表 中 己 有 同名 变量 时 ， 和 覆盖 它们 的 值 。 其 他 的 
都 不 处 理 。 可 以 用 在 已 经 定义 了 一 组 合法 的 变量 ,然后 要 从 一 个 数组 中 提取 值 覆 
盖 这 些 变量 的 场合 ， 例 如 $_REQUEST。 本 标记 是 PHP 4.2.0 新 加 的 。 

回 EXTR PREFIX IF EXISTS: 仅 在 当前 符号 表 中 已 有 同名 变量 时 ， 建 立 附加 了 前 
级 的 变量 名 ， 其 他 的 都 不 处 理 。 本 标记 是 PHP 4.2.0 新 加 的 。 

回 EXTR REFS: 将 变量 作为 引用 提取 。 这 有 力 地 表明 了 导入 的 变量 仍然 引用 了 
var_array 参数 的 值 。 可 以 单独 使 用 这 个 标志 或 者 在 extract type 中 用 OR 与 其 他 
任何 标志 结合 使 用 。 本 标记 是 PHP 4.3.0 新 加 的 。 

如 果 没 有 指定 extract type， 则 被 假定 为 EXTR_ OVERWRITE。 
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指点 迷津 : 

prefix 仅 在 extract type 的 值 是 EXTR PREFIX SAME、 EXTR PREFIX ALL、EXTR_ 
PREFIX_INVALID 或 者 EXTR PREFIX IF_EXISTS 时 需要 ， 如 果 附 加 了 前 级 后 的 结果 不 
是 合法 的 变量 名 ， 将 不 会 导入 到 符号 表 中 。 


extractO 返 回 成 功 导入 到 符号 表 中 的 变量 数目 。 
(3) mb_substr() 函 数 ， 对 字符 串 进 行 截取 操作 ， 并 且 支 持 中 文字 符 串 的 截取 。 其 语法 
如 下 : 
string mb_substr ( string str, int start [, int length [, string encoding]] ) 
mb_substr() 函 数 的 参数 说 明 如 表 14.5 所 示 。 


表 14.5 mb_substr() 函 数 的 参数 说 明 


参数 说 了 明 
str 必 选 参数 ， 指 定 操作 的 字符 串 
有 必 选 参数 ， 指 定 截取 的 开始 位 置 。 参 数 start 的 指定 位 置 是 从 0 开始 计算 的 ， 即 字符 串 中 
的 第 一 个 字符 表示 为 0 
length 指定 截取 的 字符 串 长 度 
encodin 设置 字符 串 的 编码 格式 


实例 251 Smarty 模板 中 的 关键 字 描 红 技 术 


( 实例 位 置 : 配套 资源 \SL\14\251 视频 位 置 : 配套 资源 \SP\14\251 ) 


实例 说 明 

在 Smarty 模板 中 同样 可 以 实现 关键 字 描 红 的 功能 , 其 应 用 的 是 Smarty 中 的 replace 变 
量 。 在 本 实例 中 ， 将 继续 应 用 后 台 管 理 系统 主页 实例 的 内 容 ， 编 辑 订 单 查询 模块 ， 实 现 对 
查询 关键 字 的 描 红 功能 ， 运 行 结果 如 图 14.13 所 示 。 


订单 蚀 理 => 订 单 查 词 


JE 
订单 引 : Fo7 肛交 重 置 
盏 可 [次 了 时间 ED 
1 |ol0803300761 | 机 和 技 [2010-08-12 19:50:39 | _ 床 双 天 
2 |oioe033007e2 1 2010-08-12 19:5122 | _ 忆 双 天 
3 |o10603300783 [EEE |2010-08-12 19:50:39 未 奴 理 
4 oioe03300764 | 机 入 2010-08-12 19:51:22 | Bw 到 
5 Joo603300785 [EEE |2010-08-12 19:50:39 未 多 理 
6 |oi0803300768 | 胃 B 和 琉 2010-08-12 19:51:22 | 并 
7 |010603300767 EE Jani0-08-12 19:50:39 未 你 理 
8 |0l0603300768 明日 科技 2010-08-12 19:51:22 ELE 


图 14.13 ”Smarty 模板 中 的 关键 字 描 红 
实现 过 程 
本 实例 首先 创建 一 个 Smarty 模板 页 ， 对 订单 查询 模块 的 内 容 进 行 编辑 ， 创 建 form 表 


.406 . 
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单 执行 查询 操作 ， 并 且 应 用 replace 变量 将 查询 结果 中 的 关键 字 进 行 描 红 。 | 
(1) 编辑 for_select.html 模板 页 ， 创 建 form 表单 ， 提 交 查 询 的 关键 字 ， 将 数据 提交 | 
到 for_select.php 页 面 进行 处 理 ， 同 时 在 本 页 中 应 用 section 语句 循环 输出 查询 结果 ， 并 且 | 
应 用 replace 对 查询 的 关键 字 进 行 描 红 操 作 。 其 关键 代码 如 下 : | 
{section name=id loop=$res} 
<tr> 
<td align="center" bgcolor="#FFFFFF">{$res[id].id} </td> | 
<td bgcolor="#FFFFFF"> {S$res[id].numberlreplace:$select:"<font color=#FF0000'>$select</font>"} | 
</td> | 
<td bgcolor="#FFFFFF">{$res[id].userlreplace:" 明 日 科技 ":"<font color=#FF0000> 明 日 科技 | 
</font>"}</td> | 
<td bgcolor="#FFFFFF">{$res[id].dates}</td> 
<td align="center" bgcolor="#FFFFFF">{if $res[id].type 一 0} 未 处 理 {else} 已 处 理 {/if}</td> 
</tr> 
{/section} 


(2) 编辑 for_select.php 动态 页 ,以 form 表单 中 提交 的 关键 字 为 条 件 , 执行 模糊 查询 ， 
如 果 查 询 结果 为 真 ， 则 将 查询 结果 赋 给 模板 变量 ， 同 时 将 查询 的 关键 字 也 赋 给 指定 的 模板 | 
变量 ;如果 查询 结果 为 false， 则 将 为 模板 变量 赋值 F。 其 代码 如 下 : | 


<?php 
$smarty->assign(title,"Smarty 模板 中 的 关键 字 描 红 技术 7); /定义 标题 变量 
这 $_POST[mumber]!="){ // 淹 断 查询 关键 字 是 否 为 空 | 
$sql="select * from tb_order where number like '%".$_ POST[mumber]."9%6":/ 定 义 模糊 查询 的 语句 | 
S$res=$admindb->ExecSQL($sql,$conn): // 执 行 模糊 查询 | 
if($res){ 
$smarty->assign("select",$_ POST[mumber]): // 将 查询 的 关键 字 赋 给 模板 变量 
$smarty->assign("boo","T"): // 为 模板 变量 赋值 为 
$smarty->assign("res", $res):; // 将 查询 结果 赋 给 模板 变量 
}else{ 
$smarty->assign("boo","F"); 
Bb 
}else{ 
$smarty->assign("boo","F"); 
} 
?> 
技术 要 点 


(1) Smarty 模板 中 的 关键 字 描 红 应 用 的 是 replace 变量 ， 其 实现 字符 串 的 简单 查询 和 | 
蔡 换 操作 。 其 包括 两 个 参数 ， 第 一 个 参数 是 被 蔡 换 的 文本 字符 串 ， 第 二 个 参数 是 用 来 蔡 换 | 
的 文本 字符 串 。 其 应 用 示例 如 下 : | 
{$articleTitlelreplace:"Garden":"Vineyard"} 


在 这 个 示例 中 ， 将 模板 变量 $articleTitle 中 的 Garden 替换 为 Vineyard。 | 
(2) 查询 关键 字 描 红 的 原理 : 在 PHP 动态 页 中 获取 form 表单 提交 的 查询 关键 字 ， 并 | 
且 执行 模糊 查询 ， 将 查询 结果 赋 给 模板 变量 ， 同 时 将 查询 的 关键 字 也 赋 给 模板 变量 ， 然 后 | 
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| 在 模板 页 中 ， 通 过 section 语句 循环 输出 查询 结果 ， 并 应 用 replace 将 查询 结果 中 关键 字 的 


| 字体 设置 为 红色 。 
全 A 实例 252 ”Smarty 模板 中 生成 数字 验证 码 
( 实例 位 置 : 配套 资源 \SL\14\252 视频 位 置 配套 资源 \SP\14\252 ) 
| 实例 说 明 


| 本 实例 应 用 Smarty 模板 中 的 foreach 语句 在 模板 页 中 直接 生成 一 个 数字 验证 码 ， 它 相 
| 对 于 在 动态 PHP 中 开发 的 验证 码 更 加 简单 、 实 用 。Smarty 模板 中 生成 的 验证 码 运行 结果 
| 如 图 14.14 所 示 。 


还 大 机 二 管理 台 录 


站 | REN LJ ZIYUAN GUN LX TONG 


用 产 名 : 一 一 验证 码 : [5 一 1999 
Ei 和 3 sx | 


| 交 RAR em walha et dere 
图 14.14 Smarty 模板 中 生成 数字 验证 码 
现 过 程 
具体 步骤 如 下 : 

(1) 创建 system 文件 夹 ， 封 装 Smarty 模板 的 配置 方法 ， 这 里 不 再 袭 述 。 

(2) 创建 index.php 文件 ， 生 成 验证 码 ， 并 且 将 验证 码 赋 给 模板 变量 ， 最 后 指定 模板 
| 页 。 其 代码 如 下 : 
| a 


| require_once("system/system.inc.php"): // 包 含 配置 文件 
| Sarray= explode(' ', mt_rand(1000.9999)); // 生 成 随机 验证 码 
| $smarty->assign("title','Smarty 模板 中 生成 数字 验证 码 "); // 将 指定 数据 赋 给 模板 变量 
| $smarty->assign('content.$array): // 将 数组 赋 给 模板 变量 
S$smarty->display(index html)); /指定 模板 页 
?> 


| (3) 创建 index.html 模板 文件 ， 设 计 用 户 登 录 页 面 ， 添加 用 户 登录 的 表单 元 素 。 同 时 
| 应 用 foreach 语句 输出 模板 变量 中 传递 的 验证 码 。 其 关键 代码 如 下 : 
| <form id="forml1" name="forml" method="post" action="index_ok.php"> 
<input name="user' type="text' id="user" size="10" /> 
| <input type="hidden" name="checks" value="{foreach key=key item=item from=$content} 
| {Sitem)} {/foreach}" /> 
| <input name="check" type="text" size="8" /> 
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可 
<input name="pass" type= "passwWord" id="pass" size="10" /> 
<input type="image" name="imageField" src="images/Blog 03 03.jpg" 这 | 
<input type="image" name="imageField2" onclick="form.reset():return false;" src="images/ | 
Blog 03 06jpg" /> | 
</form> 
(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 对 用 户 登 录 信息 进行 验证 。 
如 果 用 户 名 和 密码 正确 则 跳 转 到 main php 页 面 ， 否 则 跳 转 到 index.php 页 面 。 
(5) 创建 main.php 和 main.html 文件 ， 作 为 网 站 的 主页 。 
技术 要 点 | 
严格 地 说 这 个 验证 码 不 是 在 Smarty 模板 页 中 生成 的 , 只 是 通过 foreach 语句 将 PHP 动 | 
态 页 中 生成 的 验证 码 在 模板 页 中 输出 。 因 此 本 实例 开发 的 关键 是 foreach 语句 的 应 用 和 验 | 
证 码 的 生成 。 | 
(1) 应 用 mt_rand0 函 数 生 成 验证 码 。mt_rand0) 函 数 的 语法 如 下 : 
int mt_rand ( [int min, int max]) | 
如 果 mt_rand0 函 数 没有 提供 可 选 参数 min 和 max， 则 返回 0 到 RAND_MAX 之 问 的 | 
伪 随 机 数 。 | 
(2) 应 用 explode0) 函 数 将 生成 的 验证 码 写 入 到 数组 中 。explode0 函 数 的 语法 如 下 : 
array explode(string separator, string string, [int limit]) | 
返回 由 字符 串 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子囊 ， 它 们 被 字符 串 separator 
作为 边界 点 分 隔 出 来 。 如 果 设 置 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 | 
那个 元 素 将 包含 string 的 剩余 部 分 如 果 separator 为 空 字 符 串 ("")，explode() 函 数 将 返回 | 
false; 如 果 separator 所 包含 的 值 在 string 中 找 不 到 ， 那 么 explode0 函 数 将 返回 包含 string | 
单个 元 素 的 数组 ， 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 
(3) 通过 assign() 方 法 将 验证 码 数组 赋 给 模板 变量 。 
(4) 应 用 foreach 语句 循环 输出 模板 变量 中 数组 元 素 。foreach 语法 如 下 : 
{foreach name=foreach_name key=key item=item from=arr_name} 


{/foreach} 
参数 说 明 : 
name: 该 循环 的 名 称 。 
key: 当前 元 素 的 键 值 。 
item: 必 选 参数 ， 当 前 元 素 的 变量 名 。 
from: 必 选 参数 ， 该 循环 的 数组 。 
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可 
<input name="pass" type= "passwWord" id="pass" size="10" /> 
<input type="image" name="imageField" src="images/Blog 03 03.jpg" 这 | 
<input type="image" name="imageField2" onclick="form.reset():return false;" src="images/ | 
Blog 03 06jpg" /> | 
</form> 
(4) 创建 index_ok.php 文件 ， 获 取 表单 中 提交 的 数据 ， 对 用 户 登 录 信息 进行 验证 。 
如 果 用 户 名 和 密码 正确 则 跳 转 到 main php 页 面 ， 否 则 跳 转 到 index.php 页 面 。 
(5) 创建 main.php 和 main.html 文件 ， 作 为 网 站 的 主页 。 
技术 要 点 | 
严格 地 说 这 个 验证 码 不 是 在 Smarty 模板 页 中 生成 的 , 只 是 通过 foreach 语句 将 PHP 动 | 
态 页 中 生成 的 验证 码 在 模板 页 中 输出 。 因 此 本 实例 开发 的 关键 是 foreach 语句 的 应 用 和 验 | 
证 码 的 生成 。 | 
(1) 应 用 mt_rand0 函 数 生 成 验证 码 。mt_rand0) 函 数 的 语法 如 下 : 
int mt_rand ( [int min, int max]) | 
如 果 mt_rand0 函 数 没有 提供 可 选 参数 min 和 max， 则 返回 0 到 RAND_MAX 之 问 的 | 
伪 随 机 数 。 | 
(2) 应 用 explode0) 函 数 将 生成 的 验证 码 写 入 到 数组 中 。explode0 函 数 的 语法 如 下 : 
array explode(string separator, string string, [int limit]) | 
返回 由 字符 串 组 成 的 数组 ， 每 个 元 素 都 是 string 的 一 个 子囊 ， 它 们 被 字符 串 separator 
作为 边界 点 分 隔 出 来 。 如 果 设 置 limit 参数 ， 则 返回 的 数组 包含 最 多 limit 个 元 素 ， 而 最 后 | 
那个 元 素 将 包含 string 的 剩余 部 分 如 果 separator 为 空 字 符 串 ("")，explode() 函 数 将 返回 | 
false; 如 果 separator 所 包含 的 值 在 string 中 找 不 到 ， 那 么 explode0 函 数 将 返回 包含 string | 
单个 元 素 的 数组 ， 如 果 参 数 limit 是 负数 ， 则 返回 除了 最 后 的 -limit 个 元 素 外 的 所 有 元 素 。 
(3) 通过 assign() 方 法 将 验证 码 数组 赋 给 模板 变量 。 
(4) 应 用 foreach 语句 循环 输出 模板 变量 中 数组 元 素 。foreach 语法 如 下 : 
{foreach name=foreach_name key=key item=item from=arr_name} 


{/foreach} 
参数 说 明 : 
name: 该 循环 的 名 称 。 
key: 当前 元 素 的 键 值 。 
item: 必 选 参数 ， 当 前 元 素 的 变量 名 。 
from: 必 选 参数 ， 该 循环 的 数组 。 
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术 章 读者 可 以 学 到 如 下 实例 : 


PI 实例 253 
PI 实例 254 
WI 实例 255 
WI 实例 256 
WI 实例 257 
PI 实例 258 


用 户 信 息 的 查询 、 更 新 和 删除 

用 户 登 录 和 数据 的 分 页 输出 

通过 验证 码 类 和 分 页 类 完成 用 户 登 录 和 分 页 输出 
通过 ThinkPHP 中 的 扩展 类 生成 中 文 验证 码 

可 以 传递 查询 条 件 的 分 页 

应 用 ThinkPHP 中 的 扩展 类 上 传 文件 


需 
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实例 253 ”用户 信 息 的 查询 、 更 新 和 删除 
( 实例 位 置 : 配套 资源 \SL\15W253 视频 位 置 配套 资源 \SP\1S\253 ) 
实例 说 明 


本 实例 应 用 ThinkPHP 中 的 CURD 操作 ， 实 现 对 用 户 信息 的 查询 、 更 新 和 删除 操作 。 
其 运行 效果 如 图 15.1 所 示 。 


用 户 信息 
名 称 地 址 和 报 作 
长 下 市 LE 
用 户 信息 
i 名 称 : | 明日 科技 
密码 : seeeeeeeeeeeeseeeee 
地 址 : 。 吉林 市 
用 户 信息 
问 名 称 地 址 报 作 
4。 | 胃 昌 科 技 吉林 市 更 站 
五 “| 严 长春 市 更 新 而 只 
1 mr 长春 市 更 新 创 计 
Tsoft 长 春 市 更 新 钢 院 
mrsoft 四 下 市 更 新 全 及 
1 mr 攻 春 市 更 着 全 这 


图 15.1 数据 更 新 和 删除 

实现 过 程 
具体 步骤 如 下 : | 
(1) 创 建 253 项 目 根 目录 , 在 根 目 录 下 创建 项 目 文件 夹 App 和 Public 文 件 夹 存储 CSS、| 
图 片 和 JS 脚本 等 文件 。 | 
(2) 在 253 项 目 根 目 录 下 ， 编 辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 


<?php 

define(CTHINK PATH', '../ThinkPHP): // 定 义 ThinkPHP 框架 路 径 〈 相 对 于 入 口 文件 ) 
define(APP NAME','App): /定义 项 目 名 称 

define('APP PATH', ‘/App"): // 定 义 项 目 路 径 
require(THINK_PATH."/ThinkPHPphp"); 。 “”// 加 载 框架 入 口 文件 

App::run0): /实例 化 一 个 网 站 应 用 实例 

?> 


(3) 在 下 浏览 器 中 运行 入 口 文件 ， 自 动 生成 项 目 目录 。 | 
(4) 定位 到 App\Conf 目录 下 ,编辑 config php 文件 , 通过 PDO 连接 MySQL 数据 库 。 | 
其 代码 如 下 : | 
<2?php 
Tetum array( 
'IDB_TYPE=> pdo', 
/注意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 
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& 及 
DB_DSN'=> 'mysql:host=localhost:dbname=db_databasel15', 
'DB_USER'=>'root’, 

DB PWD=>'111', 

| 'DB_PREFIX'=>'think ， 

| / 其 他 项 目 配置 参数 …… 

| 'APP DEBUG' => false, // 关 闭 调试 模式 


_x" 国法 
1 之 

(5) 定位 到 App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 Index 模块 ， 继 承 系统 的 
| Action 基础 类 ， 定 义 index0 方 法 ， 以 记录 的 ID 值 为 条 件 ， 降 守 循 环 输出 10 条 记录 。 其 代 


| 码 如 下 : 
| <?php 
| header("Content-Type:text/html; charset=utf-8"); 1/ 设置 页 面 编码 格式 
class IndexAction extends Action{ 
public function indexO{ 

$db = MCUser); /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 

$select = $db->order('id desc)->limit(10)->selectO: 
| S$this->assign('select', $select); /1/ 模 板 变量 赋值 
| $this->display0; /指定 模板 页 
| } 


| 定义 update() 方 法 ， 首 先 根据 超 链接 传递 ID 值 执行 查询 ， 查 询 出 指定 的 数据 ， 并 且 将 
| 查询 结果 赋 给 指定 的 模板 变量 。 然 后 ， 判 断 表单 提交 的 ID 值 是 否 存在 ， 如 果 存 在 则 以 ID 
| 为 条 件 ， 对 指定 的 数据 进行 更 新 操作 。 其 关键 代码 如 下 : 


public function updateO{ 
$db = M('User'); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| $select = $db->where(id=-'.$_GET['id'])->selectO; 
| S$this->assign('select'. $select): /模板 变量 赋值 
| S$this->display(update); // 指 定 模 板 页 
ifisset($_ POST['id])){ 
$data["user] = $_ POST[muser]: // 要 修改 的 数据 对 象 属性 赋值 


S$data['pass'] = md5($_POST['pass'"]): 
$data['address]=$_ POST['address']; 
$result=$db->where(id=.$_POST['id"])->save($data); /根据 条 件 保存 修改 的 数据 
这 $resulb{ 

$this->redirect(Index/index',", 2,' 数 据 更 新 成 功 ); /页 面 重 定向 
} 


| } 
定义 delete0 方 法 ， 根 据 超 链 接 传 递 的 人 D 值 ， 删 除数 据 库 中 指定 的 记录 。 其 关键 代码 
如 下 : 


| public function deleteO{ 
| $db = MOCUser); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| Sresult=$db->where('id=".$_GET['id'])->delete(|); 1/ 删除 记 为 5 的 用 户 数据 
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& 及 
DB_DSN'=> 'mysql:host=localhost:dbname=db_databasel15', 
'DB_USER'=>'root’, 

DB PWD=>'111', 

| 'DB_PREFIX'=>'think ， 

| / 其 他 项 目 配置 参数 …… 

| 'APP DEBUG' => false, // 关 闭 调试 模式 


_x" 国法 
1 之 

(5) 定位 到 App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 Index 模块 ， 继 承 系统 的 
| Action 基础 类 ， 定 义 index0 方 法 ， 以 记录 的 ID 值 为 条 件 ， 降 守 循 环 输出 10 条 记录 。 其 代 


| 码 如 下 : 
| <?php 
| header("Content-Type:text/html; charset=utf-8"); 1/ 设置 页 面 编码 格式 
class IndexAction extends Action{ 
public function indexO{ 

$db = MCUser); /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 

$select = $db->order('id desc)->limit(10)->selectO: 
| S$this->assign('select', $select); /1/ 模 板 变量 赋值 
| $this->display0; /指定 模板 页 
| } 


| 定义 update() 方 法 ， 首 先 根据 超 链接 传递 ID 值 执行 查询 ， 查 询 出 指定 的 数据 ， 并 且 将 
| 查询 结果 赋 给 指定 的 模板 变量 。 然 后 ， 判 断 表单 提交 的 ID 值 是 否 存在 ， 如 果 存 在 则 以 ID 
| 为 条 件 ， 对 指定 的 数据 进行 更 新 操作 。 其 关键 代码 如 下 : 


public function updateO{ 
$db = M('User'); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| $select = $db->where(id=-'.$_GET['id'])->selectO; 
| S$this->assign('select'. $select): /模板 变量 赋值 
| S$this->display(update); // 指 定 模 板 页 
ifisset($_ POST['id])){ 
$data["user] = $_ POST[muser]: // 要 修改 的 数据 对 象 属性 赋值 


S$data['pass'] = md5($_POST['pass'"]): 
$data['address]=$_ POST['address']; 
$result=$db->where(id=.$_POST['id"])->save($data); /根据 条 件 保存 修改 的 数据 
这 $resulb{ 

$this->redirect(Index/index',", 2,' 数 据 更 新 成 功 ); /页 面 重 定向 
} 


| } 
定义 delete0 方 法 ， 根 据 超 链 接 传 递 的 人 D 值 ， 删 除数 据 库 中 指定 的 记录 。 其 关键 代码 
如 下 : 


| public function deleteO{ 
| $db = MOCUser); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| Sresult=$db->where('id=".$_GET['id'])->delete(|); 1/ 删除 记 为 5 的 用 户 数据 
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if($result){ 
S$this->redirect(Index/index',", 2. 数 据 删除 成 功 ); // 页 面 重 定向 
} 


} 


?> 


(6) 定位 到 App\Tpl\default 目录 下 ， 创 建 mdex 模块 文件 夹 。 编 辑 index 操作 的 模板 


文件 index.html， 应 用 ThinkPHP 内 管 模板 引擎 中 的 foreach 标签 循环 输出 模板 变量 传递 的 
数据 ， 创 建 更 新 和 删除 超 链 接 ， 将 指定 记录 的 ID 作为 参数 进行 传递 。 其 关键 代码 如 下 : 


<foreach name='select' item='user > 

<tr class="content"> 
<td bgcolor="#FFFFFF">&nbsp; {$user.id} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.user} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.address} </td> 
<td bgcolor="#FFFFFF"><a href=" URL /update?id={$user.id}'"> 更 新 </a>/<a href="_ URL 

_ /delete?id={$user.id} "> 删除 </a></td> 
</tr> 
</foreach> 


(7) 在 Index 模块 文件 夹 下 ， 编 辑 update.html 模板 文件 ， 创 建 表单 ， 将 从 模板 变量 
中 读 取 的 数据 作为 表单 元 素 的 默认 值 进行 输出 ， 将 表单 中 数据 提交 到 控制 器 的 update0 方 
法 中 完成 数据 的 更 新 操作 。 其 关键 代码 如 下 : 


<form id="form?2" name="form2" method="post" action=" URL _ /update"> 
<table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor= 
"#FFFFFF"> 
<foreach name='select item='user > 
<tr class="content"> 
<td bgcolor="#FFFFFF" class="right" width="103"> 名 称 : </td> 
<td bgcolor="#FFFFFF" width="289"> <input type="hidden" name="id" id="hiddenField" 
value=" {$user.id}" /><input name="user" type="text" id="user" size="20" value=" {$user.user}" /></td> 
</tr> 
<tr class="content"> 
<td bgcolor="#EFFFFF" class="right"> 密 码 : </td> 
<td bgcolor="#FFFFFF"><input ”name="pass" type="password" id="pass" size="20" 
value=" {$user.pass}" /> 
<td> 
</t> 
<tr class="content"> 
<td bgcolor="#FFFFFF" class="right">&nbsp; 地 址 : </td> 
<td bgcolor="#FFFFFF">&nbsp:; 
<input name="address" type="text" id="address" size="30" value=" {$user.address}" /> 
</td> 
</tr> 
<tr class="content"> 
<td bgcolor="#EFFFFF"><input type="submit” name="button” id="button" value=" 更 新 " 
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if($result){ 
S$this->redirect(Index/index',", 2. 数 据 删除 成 功 ); // 页 面 重 定向 
} 


} 


?> 


(6) 定位 到 App\Tpl\default 目录 下 ， 创 建 mdex 模块 文件 夹 。 编 辑 index 操作 的 模板 


文件 index.html， 应 用 ThinkPHP 内 管 模板 引擎 中 的 foreach 标签 循环 输出 模板 变量 传递 的 
数据 ， 创 建 更 新 和 删除 超 链 接 ， 将 指定 记录 的 ID 作为 参数 进行 传递 。 其 关键 代码 如 下 : 


<foreach name='select' item='user > 

<tr class="content"> 
<td bgcolor="#FFFFFF">&nbsp; {$user.id} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.user} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.address} </td> 
<td bgcolor="#FFFFFF"><a href=" URL /update?id={$user.id}'"> 更 新 </a>/<a href="_ URL 

_ /delete?id={$user.id} "> 删除 </a></td> 
</tr> 
</foreach> 


(7) 在 Index 模块 文件 夹 下 ， 编 辑 update.html 模板 文件 ， 创 建 表单 ， 将 从 模板 变量 
中 读 取 的 数据 作为 表单 元 素 的 默认 值 进行 输出 ， 将 表单 中 数据 提交 到 控制 器 的 update0 方 
法 中 完成 数据 的 更 新 操作 。 其 关键 代码 如 下 : 


<form id="form?2" name="form2" method="post" action=" URL _ /update"> 
<table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor= 
"#FFFFFF"> 
<foreach name='select item='user > 
<tr class="content"> 
<td bgcolor="#FFFFFF" class="right" width="103"> 名 称 : </td> 
<td bgcolor="#FFFFFF" width="289"> <input type="hidden" name="id" id="hiddenField" 
value=" {$user.id}" /><input name="user" type="text" id="user" size="20" value=" {$user.user}" /></td> 
</tr> 
<tr class="content"> 
<td bgcolor="#EFFFFF" class="right"> 密 码 : </td> 
<td bgcolor="#FFFFFF"><input ”name="pass" type="password" id="pass" size="20" 
value=" {$user.pass}" /> 
<td> 
</t> 
<tr class="content"> 
<td bgcolor="#FFFFFF" class="right">&nbsp; 地 址 : </td> 
<td bgcolor="#FFFFFF">&nbsp:; 
<input name="address" type="text" id="address" size="30" value=" {$user.address}" /> 
</td> 
</tr> 
<tr class="content"> 
<td bgcolor="#EFFFFF"><input type="submit” name="button” id="button" value=" 更 新 " 
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</tr> 
</foreach> 
| </table> 
| </form> 


本 章 中 所 举 实例 都 是 应 用 ThinkPHP 框架 进行 开发 ， 巩 固 读者 对 ThinkPHP 框架 技术 
| 的 理解 ， 增 强 应 用 ThinkPHP 框架 开发 实战 项 目的 能 
| 本 实例 中 的 技术 要 点 可 以 归纳 为 如 下 几 个 方面 : 
| (1) 通过 M 快捷 方法 实例 化 基础 模型 类 。 在 没有 定义 任何 模型 的 时 候 ， 可 以 使 用 下 
| 面 的 方法 实例 化 一 个 模型 类 来 进行 操作 ; 
| $User = new Model('User’); 
$User->select(); /进行 其 他 的 数据 操作 
或 者 使 用 M 快捷 方法 进行 实例 化 ， 其 效果 是 相同 的 。 
S$User = M('User'); 
$User->select(); // 进 行 其 他 的 数据 操作 
| 这 种 方法 最 简单 高 效 ， 因 为 不 需要 定义 任何 的 模型 类 ， 所 以 支持 跨 项 目 调用 。 缺 点 也 
| 是 因为 没有 自 定义 的 模型 类 , 因此 无 法 写 入 相关 的 业务 逻辑 , 只 能 完成 基本 的 CURD 操作 。 
| (2) 连贯 操作 与 CURD 操作 配合 应 用 ， 完 成 数据 的 创建 、 更 新 、 读 取 和 删除 。 
@ Where: 用 于 查询 或 者 更 新 条 件 的 定义 。 参 数 支持 字符 串 、 数 组 和 对 象 。 
| @ Order: 对 结果 进行 排序 。 排 序 方法 支持 对 多 个 字段 的 排序 ， 例 如 ，order(status desc,id 
| asc)。order() 方 法 的 参数 支持 字符 串 和 数组 ， 数 组 的 用 法 如 下 : order(array ('status'=>'desc','id'))。 
| @ Limit: 结果 限制 。 在 ThinkPHP 中 ， 无 论 操作 的 是 MySQL、MS SQL Server 还 是 
| Oracle 数据 库 ， 其 limit0 的 方法 是 统一 的 ， 即 limit('offset,length”)。 例 如 ，limit 01,10)。 获 
| 取 从 第 一 条 记录 开始 的 10 条 记录 。 
| @ 查询 ，select0 方 法 的 返回 值 是 一 个 二 维 数 组 ， 如 果 没 有 查询 到 任何 结果 的 话 ， 也 
| 是 返回 一 个 空 的 数组 。 配 合 上 面 提 到 的 连贯 操作 方法 可 以 完成 复杂 的 数据 查询 。 
| @ 更 新 : save0 方 法 在 执行 更 新 数据 的 操作 时 ， 如 果 没 有 设置 任何 更 新 条 件 ， 且 数据 
| 对 象 本 身 也 不 包含 主键 字段 ， 那 么 save( 方 法 不 会 更 新 任何 数据 库 的 记录 。 
| @ 删除 ，delete0 方 法 可 以 用 于 删除 单个 或 者 多 个 数据 ， 主 要 取决 于 删除 条 件 ， 也 就 
| 是 where0 方 法 的 参数 ， 也 可 以 用 order0 和 limit0 方 法 来 限制 要 删除 的 个 数 ， 例 如 ， 删 除 所 
| 有 状态 为 0 的 5 个 用 户 数据 按照 创建 时 间 排 序 。 代 码 如 下 : 
$User = M("User"); / 实例 化 User 对 象 
$User->where(status=0)->order(create_time)->limit(S)->delete0O: 
| (3) 在 控制 器 中 通过 assign0 方 法 为 模板 变量 赋值 ， 通 过 display0 指 定 模板 页 ， 通 过 
| redirect0 方 法 完成 页 面 的 重 定向 。 
@ 通过 assign0 方 法 将 控制 器 中 获取 的 数据 赋 给 模板 变量 。 例如 ，$this->assign(mame'， 
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</tr> 
</foreach> 
| </table> 
| </form> 


本 章 中 所 举 实例 都 是 应 用 ThinkPHP 框架 进行 开发 ， 巩 固 读者 对 ThinkPHP 框架 技术 
| 的 理解 ， 增 强 应 用 ThinkPHP 框架 开发 实战 项 目的 能 
| 本 实例 中 的 技术 要 点 可 以 归纳 为 如 下 几 个 方面 : 
| (1) 通过 M 快捷 方法 实例 化 基础 模型 类 。 在 没有 定义 任何 模型 的 时 候 ， 可 以 使 用 下 
| 面 的 方法 实例 化 一 个 模型 类 来 进行 操作 ; 
| $User = new Model('User’); 
$User->select(); /进行 其 他 的 数据 操作 
或 者 使 用 M 快捷 方法 进行 实例 化 ， 其 效果 是 相同 的 。 
S$User = M('User'); 
$User->select(); // 进 行 其 他 的 数据 操作 
| 这 种 方法 最 简单 高 效 ， 因 为 不 需要 定义 任何 的 模型 类 ， 所 以 支持 跨 项 目 调用 。 缺 点 也 
| 是 因为 没有 自 定义 的 模型 类 , 因此 无 法 写 入 相关 的 业务 逻辑 , 只 能 完成 基本 的 CURD 操作 。 
| (2) 连贯 操作 与 CURD 操作 配合 应 用 ， 完 成 数据 的 创建 、 更 新 、 读 取 和 删除 。 
@ Where: 用 于 查询 或 者 更 新 条 件 的 定义 。 参 数 支持 字符 串 、 数 组 和 对 象 。 
| @ Order: 对 结果 进行 排序 。 排 序 方法 支持 对 多 个 字段 的 排序 ， 例 如 ，order(status desc,id 
| asc)。order() 方 法 的 参数 支持 字符 串 和 数组 ， 数 组 的 用 法 如 下 : order(array ('status'=>'desc','id'))。 
| @ Limit: 结果 限制 。 在 ThinkPHP 中 ， 无 论 操作 的 是 MySQL、MS SQL Server 还 是 
| Oracle 数据 库 ， 其 limit0 的 方法 是 统一 的 ， 即 limit('offset,length”)。 例 如 ，limit 01,10)。 获 
| 取 从 第 一 条 记录 开始 的 10 条 记录 。 
| @ 查询 ，select0 方 法 的 返回 值 是 一 个 二 维 数 组 ， 如 果 没 有 查询 到 任何 结果 的 话 ， 也 
| 是 返回 一 个 空 的 数组 。 配 合 上 面 提 到 的 连贯 操作 方法 可 以 完成 复杂 的 数据 查询 。 
| @ 更 新 : save0 方 法 在 执行 更 新 数据 的 操作 时 ， 如 果 没 有 设置 任何 更 新 条 件 ， 且 数据 
| 对 象 本 身 也 不 包含 主键 字段 ， 那 么 save( 方 法 不 会 更 新 任何 数据 库 的 记录 。 
| @ 删除 ，delete0 方 法 可 以 用 于 删除 单个 或 者 多 个 数据 ， 主 要 取决 于 删除 条 件 ， 也 就 
| 是 where0 方 法 的 参数 ， 也 可 以 用 order0 和 limit0 方 法 来 限制 要 删除 的 个 数 ， 例 如 ， 删 除 所 
| 有 状态 为 0 的 5 个 用 户 数据 按照 创建 时 间 排 序 。 代 码 如 下 : 
$User = M("User"); / 实例 化 User 对 象 
$User->where(status=0)->order(create_time)->limit(S)->delete0O: 
| (3) 在 控制 器 中 通过 assign0 方 法 为 模板 变量 赋值 ， 通 过 display0 指 定 模板 页 ， 通 过 
| redirect0 方 法 完成 页 面 的 重 定向 。 
@ 通过 assign0 方 法 将 控制 器 中 获取 的 数据 赋 给 模板 变量 。 例如 ，$this->assign(mame'， 
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$value);。 


@ 通过 display0 方 法 指定 模板 页 (display(' 操 作 名 '))。 调 用 当前 模块 的 其 他 操作 模板 。 | 
例如 ， 当 前 是 User 模块 下 面 的 read 操作 ， 而 要 调用 User 模块 的 edit 操作 模版 ， ， 
S$this->display('edit');。 | 优 六 
@ 通过 redirect0) 方 法 实现 页 面 的 重 定向 。 定 义 规则 分 为 如 下 三 种 ， 第 一 种 基本 规则 ， 
指定 项 目 和 模块 ,第 二 种 数组 传 参数 ,第 三 种 不 指定 项 目 、 模块， 即 表示 当前 项 目 和 模块 。| Mote 
redirect([ 项 目 ://[ 路 由 @][ 分 组 名 -模块 /操作 ? 参数 =- 值 1[& 参 数 N- 值 NJ) | 


redirect([ 项 目 ://][ 路 由 @][ 分 组 名 -模块 /| 操作 ',array( 参 数 1=>' 值 1'[,' 参 数 N=>' 值 N') | 
$this->redirect(Index/index',", 5, 页 面 跳 转 中 ');// 停 留 5 秒 ， 跳 到 Index 模块 index 操作 ， 显 示 页 面 | 


跳 转 字样 


(4) 应 用 内 置 模板 引擎 (ThinkTemplate) 中 的 foreach 标签 在 模板 页 中 循环 输出 模板 
变量 传递 的 数据 。foreach 标签 的 语法 如 下 : | 
<foreach name="list" item="vo" > 
{$vo.id} 
{$vo.name} 
</foreach> 


foreach 标签 用 于 循环 输出 ， 它 比 volist 标签 简洁 ， 没 有 volist 标签 那么 多 的 功能 。 优 
势 是 可 以 对 对 象 进行 遍历 输出 ， 而 volist 标签 通常 是 用 于 输出 数组 。 | 


实例 254 用户 登录 和 数据 的 分 页 输出 
( 实例 位 置 : 配套 资源 \SL\1S\254 视频 位 置 配套 资源 \SP\15\254 ) 
实例 说 明 


本 实例 实现 用 户 登 录 功 能 , 将 登录 用 户 的 信息 存储 到 SESSION 变量 中 ,应 用 ThinkPHP 
中 提供 的 分 页 扩展 类 和 Page() 方 法 完成 数据 的 分 页 输出 。 其 运行 效果 如 图 15.2 所 示 。 | 
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图 15.2 用 户 登录 和 数据 的 分 页 输出 
实现 过 程 
具体 步骤 如 下 : 


(1) 创建 002 项 目 根 目录 ， 在 根 目录 下 创建 项 目 文件 夹 App 和 Public 文件 夹 存储 CSS、 
图 片 和 JS 脚本 等 文件 。 | 
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$value);。 


@ 通过 display0 方 法 指定 模板 页 (display(' 操 作 名 '))。 调 用 当前 模块 的 其 他 操作 模板 。 | 
例如 ， 当 前 是 User 模块 下 面 的 read 操作 ， 而 要 调用 User 模块 的 edit 操作 模版 ， ， 
S$this->display('edit');。 | 优 六 
@ 通过 redirect0) 方 法 实现 页 面 的 重 定向 。 定 义 规则 分 为 如 下 三 种 ， 第 一 种 基本 规则 ， 
指定 项 目 和 模块 ,第 二 种 数组 传 参数 ,第 三 种 不 指定 项 目 、 模块， 即 表示 当前 项 目 和 模块 。| Mote 
redirect([ 项 目 ://[ 路 由 @][ 分 组 名 -模块 /操作 ? 参数 =- 值 1[& 参 数 N- 值 NJ) | 


redirect([ 项 目 ://][ 路 由 @][ 分 组 名 -模块 /| 操作 ',array( 参 数 1=>' 值 1'[,' 参 数 N=>' 值 N') | 
$this->redirect(Index/index',", 5, 页 面 跳 转 中 ');// 停 留 5 秒 ， 跳 到 Index 模块 index 操作 ， 显 示 页 面 | 


跳 转 字样 


(4) 应 用 内 置 模板 引擎 (ThinkTemplate) 中 的 foreach 标签 在 模板 页 中 循环 输出 模板 
变量 传递 的 数据 。foreach 标签 的 语法 如 下 : | 
<foreach name="list" item="vo" > 
{$vo.id} 
{$vo.name} 
</foreach> 


foreach 标签 用 于 循环 输出 ， 它 比 volist 标签 简洁 ， 没 有 volist 标签 那么 多 的 功能 。 优 
势 是 可 以 对 对 象 进行 遍历 输出 ， 而 volist 标签 通常 是 用 于 输出 数组 。 | 


实例 254 用户 登录 和 数据 的 分 页 输出 
( 实例 位 置 : 配套 资源 \SL\1S\254 视频 位 置 配套 资源 \SP\15\254 ) 
实例 说 明 


本 实例 实现 用 户 登 录 功 能 , 将 登录 用 户 的 信息 存储 到 SESSION 变量 中 ,应 用 ThinkPHP 
中 提供 的 分 页 扩展 类 和 Page() 方 法 完成 数据 的 分 页 输出 。 其 运行 效果 如 图 15.2 所 示 。 | 
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实现 过 程 
具体 步骤 如 下 : 


(1) 创建 002 项 目 根 目录 ， 在 根 目录 下 创建 项 目 文件 夹 App 和 Public 文件 夹 存储 CSS、 
图 片 和 JS 脚本 等 文件 。 | 


.415 . UD 
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| b> 
| (2) 在 002 项目 根 目录 下 ,编辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
| <2php 
! define(CTHINK PATH' '../ThinkPHP): // 定 义 ThinkPHP 框架 路 径 ( 相 对 于 入 口 文件 ) 
define(CAPP NAME,', 'App); /定义 项 目 名 称 
define('APP PATH' ' /App):; /定义 项 目 路 径 
require(THINK_ PATH."/ThinkPHPphp"); // 加 载 框架 入 口 文 件 
App::run():; /实例 化 一 个 网 站 应 用 实例 
?> 


| (3) 在 正 浏 览 器 中 运行 入 口 文 件 ， 自 动 生成 项 目 目 录 。 
| (4) 定位 到 App\Conf 目录 下 ,编辑 config.php 文件 , 通过 PDO 连接 MySQL 数据 库 。 
| 其 代码 如 下 : 


<?php 
Tetum array( 

'DB_TYPE'=> 'pdo', 

// 注 意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 

'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', 

DB_USER'=>'root', 

DB PWD=>'111', 

'DB_PREFIX'=>'think ', 

/其 他 项 目 配置 参数 …… 

'APP DEBUG' => false, // 关 闭 调试 模式 
); 
?> 

(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 ， 定 义 index() 方 法 ， 验 证 用 户 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 将 
登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 将 网 页 重 定向 到 main.html 页 面 。 其 代码 如 下 : 

<?php 
Session start(: /初始 化 SESSION 变量 
header("Content-Type:text/html; charset=utf-8"); 。“ // 设 置 页 面 编码 格式 
class IndexAction extends Action{ 

public function indexO{ 

iflisset($_POST['user'])){ 
iisset($_ POST[user]) && isset($_ POST[pass])){ 


$db=M0: /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
| S$select = $db->query("select * from think_user where user="".$_POST['user']." and 
| pass=".$_ POST['pass']."™"); // 执 行 查询 语句 ， 验 证 用 户 名 和 密码 是 否 正确 
| 这 $selecb{ 


| $_SESSION['admin']=$_POST['"user']; // 将 登录 用 户 名 存储 到 SESSION 中 
| $this->redirect(Index/main',", 2, 用 户 '"$_POST['user].， 登录 成 功 ! );// 页 面 


| 重 定向 

| }else{ 

| S$this->redirect(Tndex/index',", 2. 用 户 名 或 者 密码 不 正确 ! ); // 页 面 重 定向 
} 

| }else{ 

| $this->redirect(Index/index'", 2, 用 户 名 、 密 码 不 能 为 空 ! ); 。 ”// 页 面 重 定向 

| } 

] .416 。 
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| b> 
| (2) 在 002 项目 根 目录 下 ,编辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
| <2php 
! define(CTHINK PATH' '../ThinkPHP): // 定 义 ThinkPHP 框架 路 径 ( 相 对 于 入 口 文件 ) 
define(CAPP NAME,', 'App); /定义 项 目 名 称 
define('APP PATH' ' /App):; /定义 项 目 路 径 
require(THINK_ PATH."/ThinkPHPphp"); // 加 载 框架 入 口 文 件 
App::run():; /实例 化 一 个 网 站 应 用 实例 
?> 


| (3) 在 正 浏 览 器 中 运行 入 口 文 件 ， 自 动 生成 项 目 目 录 。 
| (4) 定位 到 App\Conf 目录 下 ,编辑 config.php 文件 , 通过 PDO 连接 MySQL 数据 库 。 
| 其 代码 如 下 : 


<?php 
Tetum array( 

'DB_TYPE'=> 'pdo', 

// 注 意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 

'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', 

DB_USER'=>'root', 

DB PWD=>'111', 

'DB_PREFIX'=>'think ', 

/其 他 项 目 配置 参数 …… 

'APP DEBUG' => false, // 关 闭 调试 模式 
); 
?> 

(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 ， 定 义 index() 方 法 ， 验 证 用 户 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 将 
登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 将 网 页 重 定向 到 main.html 页 面 。 其 代码 如 下 : 

<?php 
Session start(: /初始 化 SESSION 变量 
header("Content-Type:text/html; charset=utf-8"); 。“ // 设 置 页 面 编码 格式 
class IndexAction extends Action{ 

public function indexO{ 

iflisset($_POST['user'])){ 
iisset($_ POST[user]) && isset($_ POST[pass])){ 


$db=M0: /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
| S$select = $db->query("select * from think_user where user="".$_POST['user']." and 
| pass=".$_ POST['pass']."™"); // 执 行 查询 语句 ， 验 证 用 户 名 和 密码 是 否 正确 
| 这 $selecb{ 


| $_SESSION['admin']=$_POST['"user']; // 将 登录 用 户 名 存储 到 SESSION 中 
| $this->redirect(Index/main',", 2, 用 户 '"$_POST['user].， 登录 成 功 ! );// 页 面 


| 重 定向 

| }else{ 

| S$this->redirect(Tndex/index',", 2. 用 户 名 或 者 密码 不 正确 ! ); // 页 面 重 定向 
} 

| }else{ 

| $this->redirect(Index/index'", 2, 用 户 名 、 密 码 不 能 为 空 ! ); 。 ”// 页 面 重 定向 

| } 

] .416 。 
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| b> 
| (2) 在 002 项目 根 目录 下 ,编辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
| <2php 
! define(CTHINK PATH' '../ThinkPHP): // 定 义 ThinkPHP 框架 路 径 ( 相 对 于 入 口 文件 ) 
define(CAPP NAME,', 'App); /定义 项 目 名 称 
define('APP PATH' ' /App):; /定义 项 目 路 径 
require(THINK_ PATH."/ThinkPHPphp"); // 加 载 框架 入 口 文 件 
App::run():; /实例 化 一 个 网 站 应 用 实例 
?> 


| (3) 在 正 浏 览 器 中 运行 入 口 文 件 ， 自 动 生成 项 目 目 录 。 
| (4) 定位 到 App\Conf 目录 下 ,编辑 config.php 文件 , 通过 PDO 连接 MySQL 数据 库 。 
| 其 代码 如 下 : 


<?php 
Tetum array( 

'DB_TYPE'=> 'pdo', 

// 注 意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 

'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', 

DB_USER'=>'root', 

DB PWD=>'111', 

'DB_PREFIX'=>'think ', 

/其 他 项 目 配置 参数 …… 

'APP DEBUG' => false, // 关 闭 调试 模式 
); 
?> 

(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 ， 定 义 index() 方 法 ， 验 证 用 户 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 将 
登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 将 网 页 重 定向 到 main.html 页 面 。 其 代码 如 下 : 

<?php 
Session start(: /初始 化 SESSION 变量 
header("Content-Type:text/html; charset=utf-8"); 。“ // 设 置 页 面 编码 格式 
class IndexAction extends Action{ 

public function indexO{ 

iflisset($_POST['user'])){ 
iisset($_ POST[user]) && isset($_ POST[pass])){ 


$db=M0: /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
| S$select = $db->query("select * from think_user where user="".$_POST['user']." and 
| pass=".$_ POST['pass']."™"); // 执 行 查询 语句 ， 验 证 用 户 名 和 密码 是 否 正确 
| 这 $selecb{ 


| $_SESSION['admin']=$_POST['"user']; // 将 登录 用 户 名 存储 到 SESSION 中 
| $this->redirect(Index/main',", 2, 用 户 '"$_POST['user].， 登录 成 功 ! );// 页 面 


| 重 定向 

| }else{ 

| S$this->redirect(Tndex/index',", 2. 用 户 名 或 者 密码 不 正确 ! ); // 页 面 重 定向 
} 

| }else{ 

| $this->redirect(Index/index'", 2, 用 户 名 、 密 码 不 能 为 空 ! ); 。 ”// 页 面 重 定向 

| } 

] .416 。 


人 Pp 经 各 编程 265 便 


| b> 
| (2) 在 002 项目 根 目录 下 ,编辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
| <2php 
! define(CTHINK PATH' '../ThinkPHP): // 定 义 ThinkPHP 框架 路 径 ( 相 对 于 入 口 文件 ) 
define(CAPP NAME,', 'App); /定义 项 目 名 称 
define('APP PATH' ' /App):; /定义 项 目 路 径 
require(THINK_ PATH."/ThinkPHPphp"); // 加 载 框架 入 口 文 件 
App::run():; /实例 化 一 个 网 站 应 用 实例 
?> 


| (3) 在 正 浏 览 器 中 运行 入 口 文 件 ， 自 动 生成 项 目 目 录 。 
| (4) 定位 到 App\Conf 目录 下 ,编辑 config.php 文件 , 通过 PDO 连接 MySQL 数据 库 。 
| 其 代码 如 下 : 


<?php 
Tetum array( 

'DB_TYPE'=> 'pdo', 

// 注 意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 

'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', 

DB_USER'=>'root', 

DB PWD=>'111', 

'DB_PREFIX'=>'think ', 

/其 他 项 目 配置 参数 …… 

'APP DEBUG' => false, // 关 闭 调试 模式 
); 
?> 

(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 ， 定 义 index() 方 法 ， 验 证 用 户 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 将 
登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 将 网 页 重 定向 到 main.html 页 面 。 其 代码 如 下 : 

<?php 
Session start(: /初始 化 SESSION 变量 
header("Content-Type:text/html; charset=utf-8"); 。“ // 设 置 页 面 编码 格式 
class IndexAction extends Action{ 

public function indexO{ 

iflisset($_POST['user'])){ 
iisset($_ POST[user]) && isset($_ POST[pass])){ 


$db=M0: /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
| S$select = $db->query("select * from think_user where user="".$_POST['user']." and 
| pass=".$_ POST['pass']."™"); // 执 行 查询 语句 ， 验 证 用 户 名 和 密码 是 否 正确 
| 这 $selecb{ 


| $_SESSION['admin']=$_POST['"user']; // 将 登录 用 户 名 存储 到 SESSION 中 
| $this->redirect(Index/main',", 2, 用 户 '"$_POST['user].， 登录 成 功 ! );// 页 面 


| 重 定向 

| }else{ 

| S$this->redirect(Tndex/index',", 2. 用 户 名 或 者 密码 不 正确 ! ); // 页 面 重 定向 
} 

| }else{ 

| $this->redirect(Index/index'", 2, 用 户 名 、 密 码 不 能 为 空 ! ); 。 ”// 页 面 重 定向 

| } 

] .416 。 
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| b> 
| (2) 在 002 项目 根 目录 下 ,编辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
| <2php 
! define(CTHINK PATH' '../ThinkPHP): // 定 义 ThinkPHP 框架 路 径 ( 相 对 于 入 口 文件 ) 
define(CAPP NAME,', 'App); /定义 项 目 名 称 
define('APP PATH' ' /App):; /定义 项 目 路 径 
require(THINK_ PATH."/ThinkPHPphp"); // 加 载 框架 入 口 文 件 
App::run():; /实例 化 一 个 网 站 应 用 实例 
?> 


| (3) 在 正 浏 览 器 中 运行 入 口 文 件 ， 自 动 生成 项 目 目 录 。 
| (4) 定位 到 App\Conf 目录 下 ,编辑 config.php 文件 , 通过 PDO 连接 MySQL 数据 库 。 
| 其 代码 如 下 : 


<?php 
Tetum array( 

'DB_TYPE'=> 'pdo', 

// 注 意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 

'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', 

DB_USER'=>'root', 

DB PWD=>'111', 

'DB_PREFIX'=>'think ', 

/其 他 项 目 配置 参数 …… 

'APP DEBUG' => false, // 关 闭 调试 模式 
); 
?> 

(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 ， 定 义 index() 方 法 ， 验 证 用 户 提交 的 用 户 名 和 密码 是 否 正确 ， 如 果 正 确 则 将 
登录 用 户 名 存储 到 SESSION 变量 中 ， 并 且 将 网 页 重 定向 到 main.html 页 面 。 其 代码 如 下 : 

<?php 
Session start(: /初始 化 SESSION 变量 
header("Content-Type:text/html; charset=utf-8"); 。“ // 设 置 页 面 编码 格式 
class IndexAction extends Action{ 

public function indexO{ 

iflisset($_POST['user'])){ 
iisset($_ POST[user]) && isset($_ POST[pass])){ 


$db=M0: /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
| S$select = $db->query("select * from think_user where user="".$_POST['user']." and 
| pass=".$_ POST['pass']."™"); // 执 行 查询 语句 ， 验 证 用 户 名 和 密码 是 否 正确 
| 这 $selecb{ 


| $_SESSION['admin']=$_POST['"user']; // 将 登录 用 户 名 存储 到 SESSION 中 
| $this->redirect(Index/main',", 2, 用 户 '"$_POST['user].， 登录 成 功 ! );// 页 面 


| 重 定向 

| }else{ 

| S$this->redirect(Tndex/index',", 2. 用 户 名 或 者 密码 不 正确 ! ); // 页 面 重 定向 
} 

| }else{ 

| $this->redirect(Index/index'", 2, 用 户 名 、 密 码 不 能 为 空 ! ); 。 ”// 页 面 重 定向 

| } 

] .416 。 


} 


定义 main0 方 法 ， 载 入 分 页 类 ， 完 成 数据 库 中 数据 的 分 页 查询 ， 并 且 将 查询 结果 赋 给 
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} 
S$this->display(); 


模板 变量 。 其 代码 如 下 : 
public function mainO{ 


} 


$db = M('User’); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
// 进 行 分 页 数据 查询 , 注意 page 方法 的 参数 的 前 面部 分 是 当前 的 页 数 使 用 $_GET[p] 获 取 
iflisset($_GET['p']){ // 判 断 分 页 变量 是 否 存在 
$p=$_GET['p']; 
}else{ 
Sp=1; 


} 

$list = $db->where('address="." 长 春 市 ")->order('id desc')->page($p.',1")->select();// 查 询 数 据 
S$this->assign('select', $list); // 赋 值 数 据 集 

import("ORG.Util.Page"); // 导 入 分 页 类 

$count = $db->where(address="." 长 春 市 ")->count0; ”// 查 询 满足 要 求 的 总 记录 数 

$Page =new Page($count,1); /实例 化 分 页 类 ， 传 入 总 记录 数 和 每 页 显示 的 记录 数 


$show = $Page->show0; // 分 页 显示 输出 
S$this->assign('page', $show): /赋值 分 页 输出 
S$this->display(main); // 输 出 模板 


定义 validatorcode() 方 法 , 应 用 GD 库 中 的 函数 , 根据 超 链接 传递 的 值 生成 用 户 登 录 的 
验证 码 。 其 代码 如 下 : 


public function validatorcodeO{ 
header('content-type:image/png’); /定义 标题 png 格式 图 像 
S$im = imagecreate(65, 25); // 定 义 画 布 
imagefill($im, 0, 0, imagecolorallocate($im, 200, 200, 200)); ”// 区 域 填充 
$validatorCode = $_GET['code']; /获取 提交 的 值 


imagestring($im, rand(3, 5), 10, 3, substr($validatorCode, 0, 1), imagecolorallocate($im, 0, rand(0, 
255), rand(0, 255))); 

imagestring($im, rand(3, 5), 25, 6, substr($validatorCode, 1, 1), imagecolorallocate($im, rand(0, 
255), 0, rand(0, 255))): 

imagestring($im, rand(3, 5), 36, 9, substr($validatorCode, 2, 1), imagecolorallocate($im, rand(0, 
255), rand(0, 255), 0)): 

imagestring($im, rand(3, 5). 48, 12, substr($validatorCode, 3, 1), imagecolorallocate($im, 0, rand(0, 
255), rand(0, 255))): 

imagepng($im); // 生 成 PNG 图 像 

imagedestroy(): 1/ 销毁 图 像 


} 


(6) 定位 到 App\Tpl\default 目录 下 ,创建 mdex 模块 文件 夹 。 编 辑 index 操作 的 模板 
文件 index.html， 载 入 CSS 样式 文件 和 JavaScript 文件 ， 创 建 表单 ， 完 成 用 户 登录 信息 的 
提交 操作 。 其 关键 代码 如 下 : 


<link href=" ROOT /Public/Css/style.css" rel="stylesheet" type="text/css" /> 
<s href=" ROOT_ /Public/Js/check.js" /> 


.417 . 


} 


定义 main0 方 法 ， 载 入 分 页 类 ， 完 成 数据 库 中 数据 的 分 页 查询 ， 并 且 将 查询 结果 赋 给 
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} 
S$this->display(); 


模板 变量 。 其 代码 如 下 : 
public function mainO{ 


} 


$db = M('User’); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
// 进 行 分 页 数据 查询 , 注意 page 方法 的 参数 的 前 面部 分 是 当前 的 页 数 使 用 $_GET[p] 获 取 
iflisset($_GET['p']){ // 判 断 分 页 变量 是 否 存在 
$p=$_GET['p']; 
}else{ 
Sp=1; 


} 

$list = $db->where('address="." 长 春 市 ")->order('id desc')->page($p.',1")->select();// 查 询 数 据 
S$this->assign('select', $list); // 赋 值 数 据 集 

import("ORG.Util.Page"); // 导 入 分 页 类 

$count = $db->where(address="." 长 春 市 ")->count0; ”// 查 询 满足 要 求 的 总 记录 数 

$Page =new Page($count,1); /实例 化 分 页 类 ， 传 入 总 记录 数 和 每 页 显示 的 记录 数 


$show = $Page->show0; // 分 页 显示 输出 
S$this->assign('page', $show): /赋值 分 页 输出 
S$this->display(main); // 输 出 模板 


定义 validatorcode() 方 法 , 应 用 GD 库 中 的 函数 , 根据 超 链接 传递 的 值 生成 用 户 登 录 的 
验证 码 。 其 代码 如 下 : 


public function validatorcodeO{ 
header('content-type:image/png’); /定义 标题 png 格式 图 像 
S$im = imagecreate(65, 25); // 定 义 画 布 
imagefill($im, 0, 0, imagecolorallocate($im, 200, 200, 200)); ”// 区 域 填充 
$validatorCode = $_GET['code']; /获取 提交 的 值 


imagestring($im, rand(3, 5), 10, 3, substr($validatorCode, 0, 1), imagecolorallocate($im, 0, rand(0, 
255), rand(0, 255))); 
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255), 0, rand(0, 255))): 
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imagedestroy(): 1/ 销毁 图 像 


} 


(6) 定位 到 App\Tpl\default 目录 下 ,创建 mdex 模块 文件 夹 。 编 辑 index 操作 的 模板 
文件 index.html， 载 入 CSS 样式 文件 和 JavaScript 文件 ， 创 建 表单 ， 完 成 用 户 登录 信息 的 
提交 操作 。 其 关键 代码 如 下 : 


<link href=" ROOT /Public/Css/style.css" rel="stylesheet" type="text/css" /> 
<s href=" ROOT_ /Public/Js/check.js" /> 
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<form name="form]1" method="post" action=" URL /index" onSubmit="retum chkinput(this)"> 
<table width="265" border="0" cellspacing="0" cellpadding="0"> 
<t> 
<td class="title" id="td"> 用 户 名 : </td> 
<td><input name="user" type="text" size="15" /></td> 
</tr> 
b> 
<td class="title" id="td"> 密 码 : </td> 
<td><input name="pass" type="password" size="15" /></td> 
</tr> 
<tr> 
<td class="title" id="td"> 验 证 码 :</td> 
<td> 
<input type="text" name="validatorCode" size="10" /> 
<input type="hidden" name="defValidatorCode" value="" /> 
<script language="javascript"> 


var num1=Math.round(Math.random()*10000000): // 生 成 随机 数 
var num=num!1 toString().substr(0,4); /截取 随机 数 的 前 4 个 字符 
document.write("<img name=codeimg src= URL __/validatorcode?code="+num+">"); /将 截 
取 值 传递 到 图 像 处 理 页 中 
form!1.defValidatorCode.value=num:; // 将 截取 值 赋 给 表单 中 的 隐藏 域 
function reCodeO{ // 定 义 方法 ， 重 新 生成 验证 码 
var numl=Math round(Math randomO#10000000): // 生 成 随机 数 
var num=numl ,toStringO.substr(0.4); /截取 随机 数 
document.codeimg.src=" URIL _ /validatorcode?code="+Hnum:// 将 截取 值 传递 到 图 像 处 理 页 中 
forml.defValidatorCode.value=num:; // 将 截取 值 赋 给 表单 中 的 隐藏 域 
1 
</script> 
<a href="javascript:reCode()" class="content"> 看 不 清 </a> 
</td> 
</tr> 
</table> 
oo a en 
</form> 


(7) 在 Index 模块 文件 夹 下 ， 编 辑 main.html 文件 ， 通 过 模板 引擎 中 的 SESSION 标 

签 输出 当前 登录 的 用 户 名 ， 通 过 foreach 标签 循环 输出 模板 变量 传递 的 数据 ， 最 后 输出 模 
板 变 量 传 递 的 分 页 超 链 接 。 其 关键 代码 如 下 : 

<table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor= 


HEFFFFFF"> 
<tr> 
<td colspan="3" bgcolor="#EFFFFF" class="title" align="center > 当前 登录 用 户 : {$Think session 
admin} </td> 
</tr> 


<foreach name='select item='user > 

<tr class="content"> 
<td bgcolor="#FFFFFF">&nbsp; {$user.id} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.user} </td> 


<td bgcolor="#FFFFFF">&nbsp; {$user.address}</td> 
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</tr> 
</foreach> 
<tr class="content"> 
<td colspan="3" bgcolor="#FFFFFF">&nbsp; {$page} </td> 
</tr> 
</table> 


技术 要 点 

本 实例 中 的 技术 要 点 可 以 归纳 为 两 个 方面 : 第 一 个 方面 是 通过 ThinkPHP 框架 中 的 分 

页 类 以 及 连贯 操作 Page() 方 法 实现 数据 的 分 页 输出 ; 第 二 个 方面 是 应 用 {$Think.session. | 

session idlmd5 } 标签 输出 SESSION 变量 。 | 

(1) 通过 import("ORGUtilPage"); 导 入 分 页 类 。 

import("ORG.Util. Page"); // 导 入 分 页 类 | 

(2) 实例 化 分 页 类 ， 同 时 可 以 传递 三 个 参数 : 第 一 个 是 页 面 总 记录 数 ， 第 二 个 是 每 | 

页 显示 的 记录 数 ， 第 三 个 为 可 选 参 数 ， 通 过 分 页 超 链 接 的 值 。 | 
$count = $db->where('address="." 长 春 市 ")->count(); // 查 询 满足 要 求 的 总 记录 数 


SPage = new Page($count,1); /实例 化 分 页 类 ， 传 入 总 记录 数 和 每 页 显示 的 记录 数 
(3) 调用 分 页 类 中 的 show0 方 法 ， 输 出 分 页 超 链接 。 
$show = $Page->show(); // 分 页 显示 输出 


(4) Page() 方 法 : 查询 分 页 。 属 于 新 增 特性 ， 可 以 更 加 快速 地 进行 分 页 查询 。Page | 
方法 的 用 法 和 limit 方法 类 似 ， 格 式 为 : 
Page('page[,listRows]') | 
参数 page 表示 当前 的 页 数 , 参数 listRows 表示 每 页 显示 的 记录 数 。 例 如, Page('2,10')。 | 
表示 每 页 显示 10 条 记录 ， 获 取 第 2 页 的 数据 
listRow 如 果 不 写 的 话 ， 会 读 取 limit(length') 的 值 ， 例 如 ，limit(25)->page(3):。 表 示 每 | 
页 显示 25 条 记录 ， 获 取 第 3 页 的 数据 。 如 果 limit 也 没有 设置 的 话 ， 则 默认 为 每 页 显示 20 | 


指点 迷津 : 
在 通过 Page( 方 法 进行 数据 的 分 页 查询 时 ，page 方法 的 第 一 个 参数 是 当前 的 页 数 ， 需 | 
要 使 用 $_GET['p']， 第 二 个 参数 是 当前 页 显示 的 记录 数 。 | 


实例 255 通过 验证 码 类 和 分 页 类 完成 用 户 登录 和 分 页 输出 
( 实例 位 置 : 配套 资源 \SL\15W255 视频 位 置 配套 资源 \SP\1S\255 ) | 

实例 说 明 | 
本 实例 仍然 以 用 户 登 录 和 数据 的 输出 为 背景 ， 应 用 ThinkPHP 中 提供 的 验证 码 类 和 分 
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可 
页 类 生成 验证 码 ， 完 成 数据 的 分 页 输出 。 其 运行 效果 如 图 15.3 所 示 。 


用 户 名 : mrsoft 
密码 : oo 
验证 码 : VIBE 
当前 登录 用 户 : mrsoft 


登录 用 户 信息 
盏 名 称 地 十 


1 mr 长 春 市 
6 条 记录 16 页 下 一 页 12 3 和 了 下 天 最 后 -页 


图 15.3 通过 验证 码 类 和 分 页 类 完成 用 户 登 录 和 分 页 输出 


总 娘 郑 崩 


| 实现 过 程 


| 在 讲解 实例 的 实现 步骤 过 程 中 ， 省 略 了 项 目 目录 的 创建 、 入 口 文件 的 编写 和 配置 文件 
| 的 设置 ， 其 具体 步骤 可 以 参考 实例 253 或 者 实例 254。 这 里 讲解 在 控制 器 中 如 何 完 成 数据 
| 的 添加 和 查询 操作 。 
| (1) 定位 到 \App\LibWAction\ 目 录 下 ,编写 项 目 控制 器 。 创 建 Index 模块 ， 继 承 系统 的 
| Action 基础 类 ， 定 义 index() 方 法 ， 验 证 SESSION 变量 存储 的 验证 码 与 用 户 提交 的 验证 码 
| 是 否 相 同 ， 验 证 用 户 提 交 的 用 户 名 和 密码 是 否 正 确 ， 如 果 正 确 则 将 登录 用 户 名 存储 到 
| SESSION 变量 中 ， 并 且 将 网 页 重 定向 到 main html 页 面 。 其 代码 如 下 : 
< 

session start(); 

header("Content-Type:text/html: charset=utf-8"); // 设 置 页面 编 码 格式 

class IndexAction extends Action{ 

public function indexO{ 
iflisset($_POST['user ])){ 
iftisset($_ POST[user]) && isset($_ POST[pass]) && isset($_ POST['validatorCode'])){ 

| 这 $_ SESSION[verify'] 一 md5($_ POST[validatorCode])) {// 验 证 验证 码 是 否 
| 正确 


| $db= MO:; 1/ 实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| S$select = $db->query("select * from think_ User where user=".$_ POST[user]." 
| and pass=".$_ POST[pass]"); // 执 行 查询 语句 ， 验 证 用 户 名 和 密码 是 否 正确 
| if($select){ 
$_SESSION['admin']=$_POST['user']; 

| S$this->redirect(JIndex/main',", 2. 用 户 '$_ POST[user]' 登录 成 功 ! ");// 页 
| 面 重 定向 
| Jelse{ 
| S$this->redirect(Tndex/index',",2,' 用 户 名 或 者 密码 不 正确 ! ):/ 页 面 重 
| 定向 
| } 

jelse{ 

$this->redirect(Index/index',", 2, 验 证 码 不 正确 ! ); 。”// 页 面 重 定向 
jelse{ 
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$this->redirect(Index/index'", 2,' 用 户 名 、 密 码 不 能 为 空 ! ); /页 面 重 定向 
} 
} 
$this->display0: 
} 


定义 main0) 方 法 ， 载 入 分 页 类 ， 完 成 数据 库 中 数据 的 分 页 查询 ， 并 且 将 查询 结果 赋 给 


模板 变量 。 这 里 应 用 的 是 Page 类 和 Limit() 方 法 完成 数据 的 分 页 输出 ， 其 代码 如 下 : 


public function mainO{ 
$db = M('User’); /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
import("ORG.Util.Page"): // 导 入 分 页 类 
S$count = $db->count(); // 统 计 总 记录 数 
//$count = $User->where("status=1")->count(); // 查 询 满 足 要 求 的 总 记录 数 
$Page=new Page($count,1); /实例 化 分 页 类 传 入 总 记录 数 和 每 页 显示 的 记录 数 
Sshow = $Page->show(); // 分 页 显示 输出 


1/ 进行 分 页 数据 查询 ， 注 意 limit 方法 的 参数 要 使 用 Page 类 的 属性 
$list = $db->order('id")->limit($Page->firstRow.',".$Page->listRows)->select(); 


S$this->assign('select', $list); /赋值 数据 集 
Sthis->assign('page', $show); // 赋 值 分 页 输出 
S$this->display(main); // 输 出 模板 


} 
定义 verify0 方 法 ， 载 入 ThinkPHP 中 提供 的 验证 码 扩展 类 ， 调 用 buildImageVerify0 方 
法 生成 验证 码 。 其 代码 如 下 : 


public function verifyO{ 
import("ORG.Util.Image"): // 载 入 验证 码 类 
image::buildImageVerify(4,5,'png','65','30"','verify"); // 生 成 验证 码 

} 


(2) 定位 到 App\Tpl\default 目录 下 ， 创 建 Index 模块 文件 夹 。 编 辑 index 操作 的 模板 
文件 index.html， 载 入 CSS 样式 文件 和 JavaScript 文件 ， 创 建 表单 ， 完 成 用 户 登 录 信息 的 
提交 操作 ， 通 过 img 标签 输出 生成 的 验证 码 。 其 关键 代码 如 下 : 
<link href=" _ ROOT__/Public/Css/style.css" rel="stylesheet" type="text/css" /> 
<js href=" ROOT_ /Public/Js/check.js" /> 
<form name="forml" method="post" action=" URL /index" onSubmit="retum chkinput(this)" > 
<table width="265" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td class="title" id="td"> 用 户 名 : </td> 
<td><input name="user" type="text" size="15" /></td> 
</t> 
<tr> 
<td class="title" id= "td 密码 : </td> 
<td><input name="pass" type="password" size="15" /></td> 
</tr> 
<tr> 
<td class="title" id="td"> 验 证 码 : </td> 
<td><input type="text" name="validatorCode" size="10" /></td> 
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$this->redirect(Index/index'", 2,' 用 户 名 、 密 码 不 能 为 空 ! ); /页 面 重 定向 
} 
} 
$this->display0: 
} 


定义 main0) 方 法 ， 载 入 分 页 类 ， 完 成 数据 库 中 数据 的 分 页 查询 ， 并 且 将 查询 结果 赋 给 


模板 变量 。 这 里 应 用 的 是 Page 类 和 Limit() 方 法 完成 数据 的 分 页 输出 ， 其 代码 如 下 : 


public function mainO{ 
$db = M('User’); /实例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 绥 
import("ORG.Util.Page"): // 导 入 分 页 类 
S$count = $db->count(); // 统 计 总 记录 数 
//$count = $User->where("status=1")->count(); // 查 询 满 足 要 求 的 总 记录 数 
$Page=new Page($count,1); /实例 化 分 页 类 传 入 总 记录 数 和 每 页 显示 的 记录 数 
Sshow = $Page->show(); // 分 页 显示 输出 


1/ 进行 分 页 数据 查询 ， 注 意 limit 方法 的 参数 要 使 用 Page 类 的 属性 
$list = $db->order('id")->limit($Page->firstRow.',".$Page->listRows)->select(); 


S$this->assign('select', $list); /赋值 数据 集 
Sthis->assign('page', $show); // 赋 值 分 页 输出 
S$this->display(main); // 输 出 模板 


} 
定义 verify0 方 法 ， 载 入 ThinkPHP 中 提供 的 验证 码 扩展 类 ， 调 用 buildImageVerify0 方 
法 生成 验证 码 。 其 代码 如 下 : 


public function verifyO{ 
import("ORG.Util.Image"): // 载 入 验证 码 类 
image::buildImageVerify(4,5,'png','65','30"','verify"); // 生 成 验证 码 

} 


(2) 定位 到 App\Tpl\default 目录 下 ， 创 建 Index 模块 文件 夹 。 编 辑 index 操作 的 模板 
文件 index.html， 载 入 CSS 样式 文件 和 JavaScript 文件 ， 创 建 表单 ， 完 成 用 户 登 录 信息 的 
提交 操作 ， 通 过 img 标签 输出 生成 的 验证 码 。 其 关键 代码 如 下 : 
<link href=" _ ROOT__/Public/Css/style.css" rel="stylesheet" type="text/css" /> 
<js href=" ROOT_ /Public/Js/check.js" /> 
<form name="forml" method="post" action=" URL /index" onSubmit="retum chkinput(this)" > 
<table width="265" border="0" cellspacing="0" cellpadding="0"> 
<tr> 
<td class="title" id="td"> 用 户 名 : </td> 
<td><input name="user" type="text" size="15" /></td> 
</t> 
<tr> 
<td class="title" id= "td 密码 : </td> 
<td><input name="pass" type="password" size="15" /></td> 
</tr> 
<tr> 
<td class="title" id="td"> 验 证 码 : </td> 
<td><input type="text" name="validatorCode" size="10" /></td> 
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<td><img src=" APP_ /Index/venify/" /></td> 
</t> 
</table> 
</form> 


脚下 留神 : 
这 里 应 用 的 验证 码 是 区 分 字母 的 大 小 写 的 。 


(3) 在 Index 模块 文件 夹 下 ， 编 辑 main html 文件 ， 通 过 模板 引擎 中 的 SESSION 标 


| 签 输出 当前 登录 的 用 户 名 ， 通 过 foreach 标签 循环 输出 模板 变量 传递 的 数据 ， 最 后 输出 模 


板 变 量 传递 的 分 页 超 链 接 。 其 关键 代码 如 下 : 
<table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor= 


| "AEFFFFF"> 

| <tr> 

| <td colspan="3" bgcolor="#EFFFFF" class="title" align="center"> 当 前 登录 用 户 : {$Think.session. 
| admin}</td> 

| </tr> 


技术 要 点 


<foreach name='select item=user > 

<tr class="content"> 
<td bgcolor="#FFFFFF">&nbsp; {$user.id} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.user} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.address}</td> 

</tr> 

</foreach> 

<tr class="content"> 
<td colspan="3" bgcolor="#FFFFFF">&nbsp; {$page}</td> 
</tr> 
</table> 


buildImageVerify0 方 法 的 语法 如 下 : 
buildImageVerify($length, $mode,$type, $width, $height. $verifyName) 
参数 说 明 如 表 15.1 所 示 。 
表 15.1 验证 码 类 中 buildImageVerify() 方 法 的 参数 说 明 


参数 说 明 

length 验证 码 的 长 度 ， 默 认为 4 位 数 

a 验证 字符 串 的 类 型 ， 默 认为 数字 ， 其 他 支持 类 型 有 0 字母 1 数字 2 大 写字 母 3 小 
写字 母 4 中文 5 混合 (去 掉 了 容易 混淆 的 字符 oOLI 和 数字 01) 

type 验证 码 的 图 片 类 型 ， 默 认为 png 

Width 验证 码 的 宽度 ， 默 认 会 自动 根据 验证 码 长 度 自动 计算 

height 验证 码 的 高 度 ， 默 认为 22 


VerifyName 验证 码 的 SESSION 记录 名 称 ， 默 认为 verify 
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<td><img src=" APP_ /Index/venify/" /></td> 
</t> 
</table> 
</form> 


脚下 留神 : 
这 里 应 用 的 验证 码 是 区 分 字母 的 大 小 写 的 。 


(3) 在 Index 模块 文件 夹 下 ， 编 辑 main html 文件 ， 通 过 模板 引擎 中 的 SESSION 标 


| 签 输出 当前 登录 的 用 户 名 ， 通 过 foreach 标签 循环 输出 模板 变量 传递 的 数据 ， 最 后 输出 模 


板 变 量 传递 的 分 页 超 链 接 。 其 关键 代码 如 下 : 
<table width="405" border="1" cellpadding="1" cellspacing="1" bgcolor="#99CC33" bordercolor= 


| "AEFFFFF"> 

| <tr> 

| <td colspan="3" bgcolor="#EFFFFF" class="title" align="center"> 当 前 登录 用 户 : {$Think.session. 
| admin}</td> 

| </tr> 


技术 要 点 


<foreach name='select item=user > 

<tr class="content"> 
<td bgcolor="#FFFFFF">&nbsp; {$user.id} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.user} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.address}</td> 

</tr> 

</foreach> 

<tr class="content"> 
<td colspan="3" bgcolor="#FFFFFF">&nbsp; {$page}</td> 
</tr> 
</table> 


buildImageVerify0 方 法 的 语法 如 下 : 
buildImageVerify($length, $mode,$type, $width, $height. $verifyName) 
参数 说 明 如 表 15.1 所 示 。 
表 15.1 验证 码 类 中 buildImageVerify() 方 法 的 参数 说 明 


参数 说 明 

length 验证 码 的 长 度 ， 默 认为 4 位 数 

a 验证 字符 串 的 类 型 ， 默 认为 数字 ， 其 他 支持 类 型 有 0 字母 1 数字 2 大 写字 母 3 小 
写字 母 4 中文 5 混合 (去 掉 了 容易 混淆 的 字符 oOLI 和 数字 01) 

type 验证 码 的 图 片 类 型 ， 默 认为 png 

Width 验证 码 的 宽度 ， 默 认 会 自动 根据 验证 码 长 度 自动 计算 

height 验证 码 的 高 度 ， 默 认为 22 


VerifyName 验证 码 的 SESSION 记录 名 称 ， 默 认为 verify 
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多 学 两 招 : | 
生成 验证 码 之 后 ,需要 在 模板 页 中 通过 <img src=" APP /Index/verify/" 这 输出 生 成 的 | 

验证 码 图 像 ; 在 控制 器 中 通过 如 下 代码 : | 

if($_SESSION['verify'] (= md5($_POST['verify"])) { 
$this->error(' 验 证 码 错误 ! 小 

} 

验证 用 户 提 交 的 验证 码 是 否 正 确 。 


实例 256 通过 ThinkPHP 中 的 扩展 类 生成 中 文 验 证 码 


( 实例 位 置 配套 资源 \SL\1S\256 视频 位 置 : 配套 资源 \SP\15W256 ) 


实例 说 明 
通过 ThinkPHP 框架 实现 用 户 登录 功能 ， 
载 入 ThinkPHP\Lib\ORG\Util\mage.class.php 中 


的 Image 类 ， 调 用 其 中 的 GBVerify0 方 法 ， 生 BB: 00000s se 
成 中 文 验证 码 。 其 运行 效果 如 图 15.4 所 示 。 Se 


实现 过 程 ， 登录 重 置 

本 实例 的 实现 过 程 与 实例 255 相同 , 都 是 图 154 通过 ThinkPHP 中 的 扩展 类 
实现 用 户 登 录 和 数据 的 分 页 输出 功能 , 所 以 有 生成 中 文 验证 码 
关 本 实例 的 实现 过 程 可 以 参考 实例 255， 这 里 
不 再 袭 述 。 这 里 将 重点 讲解 它们 的 不 同 之 处 ， 用 户 登 录 中 采用 的 中 文 验证 码 。 

定位 到 \App\Lib\Action\ 目 录 下 ， 在 项 目 控制 器 的 Index 模块 中 ， 定 义 verify0 方 法 ， 
载 入 ThinkPHP 中 提供 的 验证 码 扩展 类 ， 调 用 GBVerify0 方 法 生成 中 文 验证 码 。 其 代码 | 
如 下 : 


public function verifyO{ 
import("ORG.Util.Image"): // 载 入 验证 码 类 
image::buildImageVerify(4,5,'png','65'",'30','verify’); // 生 成 中 文 验证 码 
} 


这 是 本 实例 中 唯一 与 上 一 实例 的 不 同 之 处 ， 也 是 本 实例 的 一 个 亮点 ， 有 关 本 实例 其 他 | 
步骤 的 实现 过 程 可 以 参考 上 一 实例 或 者 配套 资源 源码 ， 这 里 不 再 次 述 。 | 


指点 迷津 : | 
要 应 用 ThinkPHP 2.1 版 本 提供 的 Image 扩展 类 完成 中 文 验证 码 的 生成 ， 需 要 对 \Lib\ | 
ORG\Util\mage.class.php 文 件 中 386 行 的 “msubstr” 进 行 修改 ,将 其 修改 为 “String::msubstr”， | 
否则 直接 运行 程序 是 不 能 输出 中 文 验证 码 的 。 | 


Be Poe Se 


第 15 章 IThinkPHP 框架 § 


多 学 两 招 : | 
生成 验证 码 之 后 ,需要 在 模板 页 中 通过 <img src=" APP /Index/verify/" 这 输出 生 成 的 | 

验证 码 图 像 ; 在 控制 器 中 通过 如 下 代码 : | 

if($_SESSION['verify'] (= md5($_POST['verify"])) { 
$this->error(' 验 证 码 错误 ! 小 

} 

验证 用 户 提 交 的 验证 码 是 否 正 确 。 


实例 256 通过 ThinkPHP 中 的 扩展 类 生成 中 文 验 证 码 


( 实例 位 置 配套 资源 \SL\1S\256 视频 位 置 : 配套 资源 \SP\15W256 ) 


实例 说 明 
通过 ThinkPHP 框架 实现 用 户 登录 功能 ， 
载 入 ThinkPHP\Lib\ORG\Util\mage.class.php 中 


的 Image 类 ， 调 用 其 中 的 GBVerify0 方 法 ， 生 BB: 00000s se 
成 中 文 验证 码 。 其 运行 效果 如 图 15.4 所 示 。 Se 


实现 过 程 ， 登录 重 置 

本 实例 的 实现 过 程 与 实例 255 相同 , 都 是 图 154 通过 ThinkPHP 中 的 扩展 类 
实现 用 户 登 录 和 数据 的 分 页 输出 功能 , 所 以 有 生成 中 文 验证 码 
关 本 实例 的 实现 过 程 可 以 参考 实例 255， 这 里 
不 再 袭 述 。 这 里 将 重点 讲解 它们 的 不 同 之 处 ， 用 户 登 录 中 采用 的 中 文 验证 码 。 

定位 到 \App\Lib\Action\ 目 录 下 ， 在 项 目 控制 器 的 Index 模块 中 ， 定 义 verify0 方 法 ， 
载 入 ThinkPHP 中 提供 的 验证 码 扩展 类 ， 调 用 GBVerify0 方 法 生成 中 文 验证 码 。 其 代码 | 
如 下 : 


public function verifyO{ 
import("ORG.Util.Image"): // 载 入 验证 码 类 
image::buildImageVerify(4,5,'png','65'",'30','verify’); // 生 成 中 文 验证 码 
} 


这 是 本 实例 中 唯一 与 上 一 实例 的 不 同 之 处 ， 也 是 本 实例 的 一 个 亮点 ， 有 关 本 实例 其 他 | 
步骤 的 实现 过 程 可 以 参考 上 一 实例 或 者 配套 资源 源码 ， 这 里 不 再 次 述 。 | 


指点 迷津 : | 
要 应 用 ThinkPHP 2.1 版 本 提供 的 Image 扩展 类 完成 中 文 验证 码 的 生成 ， 需 要 对 \Lib\ | 
ORG\Util\mage.class.php 文 件 中 386 行 的 “msubstr” 进 行 修改 ,将 其 修改 为 “String::msubstr”， | 
否则 直接 运行 程序 是 不 能 输出 中 文 验证 码 的 。 | 
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GBVerify 0 方法 的 语法 如 下 : 
GBVerify ($length.$type, $width,$height, $fontface,. $verifyName) 
参数 说 明 如 表 15.2 所 示 。 
表 15.2 验证 码 类 中 GBVerify() 方 法 的 参数 说 明 


参数 说 了 明 
length 验证 码 的 长 度 ， 默 认为 4 位 数 


type 验证 码 的 图 片 类 型 ， 默 认为 png 
type 验证 但 的 图 片 类 型 ， 默 认为 png 


width 验证 码 的 宽度 ， 默 认 会 自动 根据 验证 码 长 度 自 动 计算 

height 验证 码 的 高 度 ， 默 认为 50 

verifyName 验证 码 的 SESSION 记录 名 称 ， 默 认为 verify 
使 用 的 字体 ， 使 用 完整 文件 名 或 者 放 到 图 像 类 所 在 的 目录 下 面 ， 默 认 使 用 的 字体 文 
件 是 simhei.tt 
verifyName 验证 码 的 SESSION 记录 名 称 ， 默 认为 verify 


fontface 


指点 迷津 : 
在 应 用 GBVerify () 方 法 生成 中 文 验证 码 时 ， 必 须 注意 以 下 几 个 问题 。 
(1) PHP 是 否 已 经 安装 GD 库 支 持 ; 
(2) 输出 之 前 是 否 有 任何 的 输出 (尤其 是 UTF-8 的 头 信息 输出 ); 
(3) Image 类 库 是 否 正确 导入 ; 
(4) 如 果 是 中 文 验证 码 检 查 是 否 有 复制 字体 文件 到 类 库 所 在 目录 。 


实例 257 可 以 传递 查询 条 件 的 分 页 


( 实例 位 置 : 配套 资源 \SL\15W257 视频 位 置 : 配套 资源 \SP\1S\257 ) 


实例 说 明 

本 实例 通过 TinkPHP 框架 开发 一 个 站 
内 搜索 的 功能 , 并 且 对 查询 结果 进行 分 页 输 局 
出 。 其 运行 结果 如 图 15.5 所 示 。 二 


实现 过 程 4 条 好 站 页 上 = 页 去 -页 1234 
I 图 15.5 可 以 传递 查询 条 件 的 分 页 
具体 步骤 如 下 : 


(1) 创建 005 项 目 根 目 录 ， 在 根 目 录 下 创建 项 目 文件 夹 App 和 Public 文件 夹 存储 CSS、 
图 片 和 JS 脚本 等 文件 。 
(2) 在 005 项 目 根 目 录 下 ， 编 辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
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GBVerify 0 方法 的 语法 如 下 : 
GBVerify ($length.$type, $width,$height, $fontface,. $verifyName) 
参数 说 明 如 表 15.2 所 示 。 
表 15.2 验证 码 类 中 GBVerify() 方 法 的 参数 说 明 


参数 说 了 明 
length 验证 码 的 长 度 ， 默 认为 4 位 数 


type 验证 码 的 图 片 类 型 ， 默 认为 png 
type 验证 但 的 图 片 类 型 ， 默 认为 png 


width 验证 码 的 宽度 ， 默 认 会 自动 根据 验证 码 长 度 自 动 计算 

height 验证 码 的 高 度 ， 默 认为 50 

verifyName 验证 码 的 SESSION 记录 名 称 ， 默 认为 verify 
使 用 的 字体 ， 使 用 完整 文件 名 或 者 放 到 图 像 类 所 在 的 目录 下 面 ， 默 认 使 用 的 字体 文 
件 是 simhei.tt 
verifyName 验证 码 的 SESSION 记录 名 称 ， 默 认为 verify 


fontface 


指点 迷津 : 
在 应 用 GBVerify () 方 法 生成 中 文 验证 码 时 ， 必 须 注意 以 下 几 个 问题 。 
(1) PHP 是 否 已 经 安装 GD 库 支 持 ; 
(2) 输出 之 前 是 否 有 任何 的 输出 (尤其 是 UTF-8 的 头 信息 输出 ); 
(3) Image 类 库 是 否 正确 导入 ; 
(4) 如 果 是 中 文 验证 码 检 查 是 否 有 复制 字体 文件 到 类 库 所 在 目录 。 


实例 257 可 以 传递 查询 条 件 的 分 页 


( 实例 位 置 : 配套 资源 \SL\15W257 视频 位 置 : 配套 资源 \SP\1S\257 ) 


实例 说 明 

本 实例 通过 TinkPHP 框架 开发 一 个 站 
内 搜索 的 功能 , 并 且 对 查询 结果 进行 分 页 输 局 
出 。 其 运行 结果 如 图 15.5 所 示 。 二 


实现 过 程 4 条 好 站 页 上 = 页 去 -页 1234 
I 图 15.5 可 以 传递 查询 条 件 的 分 页 
具体 步骤 如 下 : 


(1) 创建 005 项 目 根 目 录 ， 在 根 目 录 下 创建 项 目 文件 夹 App 和 Public 文件 夹 存储 CSS、 
图 片 和 JS 脚本 等 文件 。 
(2) 在 005 项 目 根 目 录 下 ， 编 辑 index.php 入 口 文件 。 其 关键 代码 如 下 : 
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<?php 

define(CTHINK PATH',' /ThinkPHP): /定义 ThinkPHP 框架 路 径 〈 相 对 于 入 口 文件 ) 
define(APP NAME', 'App): /定义 项 目 名 称 

define('APP PATH', ',/App): /定义 项 目 路 径 

Iequire(THINK PATH."/ThinkPHPphp"); /加 载 框架 入 口 文件 

App:Tumn0; /实例 化 一 个 网 站 应 用 实例 

ye 


(3) 在 正 浏 览 器 中 运行 入 口 文件 ， 自 动 生成 项 目 目录 。 | 
(4) 定位 到 App\Conf 目录 下 ， 创 建 config.php 文件 ， 通 过 PDO 连接 MySQL 数据 库 。 
其 代码 如 下 : 


<?php 
Tetum array( 
DB_TYPE'=> 'pdo'， | 
/注意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 | 
'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', | 
'DB_USER'=>'root', | 
DB PWD'=>"111', | 
IDB_PREFIX=>'think ', | 
// 其 他 项 目 配 置 参数 …… | 
'APP DEBUG' => false, // 关 闭 调试 模式 | 
); 
?> | 
(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 Index 模块 ， 继 承 系统 的 | 
Action 基础 类 ， 定 义 index0 方 法 。 首 先 ， 获 取 查 询 关 键 字 (通过 $_POST 获取 表单 提交 的 | 
查询 关键 字 ; 通过 $_GET 获取 超 链接 传递 的 查询 关键 字 ， 这 是 查询 结果 分 页 输出 的 关键 )， | 
并 且 将 其 赋 给 指定 的 变量 。 其 代码 如 下 : | 


ophp 


session start(): // 初 始 化 SESSION 变量 | 
header("Content-Type:text/html: charset=utf-8"):; /设置 页 面 编码 格式 | 
class IndexAction extends Action{ | 
public function indexO{ 
iflisset($_POST['key']) { // 判 断 查询 的 关键 字 是 否 存在 


Skey=$_POST['key']: 
}else if(isset($_GET['key']){ | 


$key=$_GET['key']; | 
} | 

然后 ， 实 例 化 基础 模型 类 ， 载 入 分 页 类 。 其 代码 如 下 : 
$db = MCUser): // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 | 
import("ORG.Util Page"): // 导 入 分 页 类 | 


接着 ,判断 查询 关键 字 是 否 存 在 ， 如 果 存 在 ， 则 根据 获取 的 关键 字 执 行 模糊 查询 ， 并 
且 对 查询 结果 进行 分 页 输出 ; 如 果 不 存在 ， 则 对 数据 库 中 的 所 有 数据 进行 分 页 输出 。 其 代 
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<?php 

define(CTHINK PATH',' /ThinkPHP): /定义 ThinkPHP 框架 路 径 〈 相 对 于 入 口 文件 ) 
define(APP NAME', 'App): /定义 项 目 名 称 

define('APP PATH', ',/App): /定义 项 目 路 径 

Iequire(THINK PATH."/ThinkPHPphp"); /加 载 框架 入 口 文件 

App:Tumn0; /实例 化 一 个 网 站 应 用 实例 

ye 


(3) 在 正 浏 览 器 中 运行 入 口 文件 ， 自 动 生成 项 目 目录 。 | 
(4) 定位 到 App\Conf 目录 下 ， 创 建 config.php 文件 ， 通 过 PDO 连接 MySQL 数据 库 。 
其 代码 如 下 : 


<?php 
Tetum array( 
DB_TYPE'=> 'pdo'， | 
/注意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 | 
'DB_DSN'=> 'mysql:host=localhost:dbname=db_database15', | 
'DB_USER'=>'root', | 
DB PWD'=>"111', | 
IDB_PREFIX=>'think ', | 
// 其 他 项 目 配 置 参数 …… | 
'APP DEBUG' => false, // 关 闭 调试 模式 | 
); 
?> | 
(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 Index 模块 ， 继 承 系统 的 | 
Action 基础 类 ， 定 义 index0 方 法 。 首 先 ， 获 取 查 询 关 键 字 (通过 $_POST 获取 表单 提交 的 | 
查询 关键 字 ; 通过 $_GET 获取 超 链接 传递 的 查询 关键 字 ， 这 是 查询 结果 分 页 输出 的 关键 )， | 
并 且 将 其 赋 给 指定 的 变量 。 其 代码 如 下 : | 


ophp 


session start(): // 初 始 化 SESSION 变量 | 
header("Content-Type:text/html: charset=utf-8"):; /设置 页 面 编码 格式 | 
class IndexAction extends Action{ | 
public function indexO{ 
iflisset($_POST['key']) { // 判 断 查询 的 关键 字 是 否 存在 


Skey=$_POST['key']: 
}else if(isset($_GET['key']){ | 


$key=$_GET['key']; | 
} | 

然后 ， 实 例 化 基础 模型 类 ， 载 入 分 页 类 。 其 代码 如 下 : 
$db = MCUser): // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 | 
import("ORG.Util Page"): // 导 入 分 页 类 | 


接着 ,判断 查询 关键 字 是 否 存 在 ， 如 果 存 在 ， 则 根据 获取 的 关键 字 执 行 模糊 查询 ， 并 
且 对 查询 结果 进行 分 页 输出 ; 如 果 不 存在 ， 则 对 数据 库 中 的 所 有 数据 进行 分 页 输出 。 其 代 
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码 如 下 : 


if($key!="){ 
Smap="user like(96".Skey "96) or address like('%6". $key."96) ": 
S$list = $db->where($map)->order('id desc')->page($_ GET['p'].',1")->selectO:; 
S$this->assign('select', $list); /赋值 数据 集 
$count = $db->where($map)->count(); // 查 询 满足 要 求 的 总 记录 数 
$Page = new Page($count,1,'key=".Skey); /实例 化 分 页 类 传 入 总 记录 数 、 每 页 显 
示 的 记录 数 和 查询 的 关键 字 


$show = $Page->show(); // 分 页 显示 输出 
Sthis->assign('‘page', $show); /赋值 分 页 输出 

jelse{ 
$count = $db->count(): // 统 计 总 记录 数 
$Page = new Page($count,1); /实例 化 分 页 类 ， 传 入 总 记录 数 和 每 页 显示 的 记录 数 
S$show = $Page->show(); // 分 页 显示 输出 


// 进 行 分 页 数据 查询 ， 注 意 limit 方法 的 参数 要 使 用 Page 类 的 属性 
$list = $db->order('id'")->limit($Page->firstRow.','.$Page->listRows)->select(); 


S$this->assign('select', $list); /赋值 数据 集 
S$this->assign('‘page', $show); /赋值 分 页 输出 
} 
最 后 ， 应 用 display0 方 法 指定 模板 页 。 其 代码 如 下 : 
S$this->displayO; /输出 模板 
} 
} 
3 


(6) 定位 到 App\Tpl\default 目录 下 ， 创 建 mdex 模块 文件 夹 。 编 辑 index 操作 的 模板 
文件 index.html， 载 入 CSS 样式 文件 ; 创建 表单 ， 提 交 查 询 的 关键 字 ;， 应 用 foreach 语句 完 
成 查询 结果 的 分 页 输出 ， 应 用 {$page} 输 出 分 页 超 链接 。 其 关键 代码 如 下 : 


<link href=" _ ROOT__ /Public/Css/style.css" rel="stylesheet" type="text/css" /> 
<form id="forml1" name="forml" method="post" action=" URL /index"> 
站 内 搜索 : 
<input type="text" name="key" id="key" /> 
<input type="submit" name="button" id="button" value=" 提 交 " /> 
</form> 
<foreach name='select item='user > 
<tr class="content"> 
<td bgcolor="#FFFFFF">&nbsp; {$user.id} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.user} </td> 
<td bgcolor="#FFFFFF">&nbsp; {$user.address}</td> 
</tr> 
</foreach> 
<tr class="content"> 
<td colspan="3" bgcolor="#FFFFFF">&nbsp; {$page} </td> 
</t> 


技术 要 点 
查询 条 件 在 分 页 超 链接 中 的 传递 ， 关 键 是 在 实例 化 Page 类 中 第 三 个 参数 〈$parameter) 
. 426 . 


的 设置 ， 此 参数 定义 的 是 在 分 页 超 链 接 中 传递 的 参数 名 称 和 对 应 的 参数 值 。 大 关 代码 
如 下 : 


SPage = new Page($count,1,'key=".$key); | 
第 一 个 参数 是 查询 的 总 记录 数 ; 第 二 个 参数 是 每 页 显示 的 记录 数 ， 第 三 参数 是 在 分 页 | 
超 链接 中 传递 的 参数 和 参数 值 | 


实例 258 应 用 ThinkPHP 中 的 扩展 类 上 传 文件 


( 实例 位 置 配套 资源 \SL\15W258 视频 位 置 配套 资源 \SP\15W258) 


实例 说 明 | 
本 实例 应 用 ThinkPHP 中 的 文件 上 传 扩展 类 (Lib\ORG\Net\UploadFile.class.php) 实现 


文件 上 传 的 功能 ， 上 传 jpg、gif 或 者 png 格式 的 图 片 到 服务 器 指定 的 文件 夹 下 ， 文件 上 传 
和 浏览 的 运行 效果 如 图 15.6 所 示 。 | 


文件 上 入 a 
选择 文件 ， les\INTEnEJERIES [浏览 [提交 ; 


上 传 图 片 : CIMG0917.JPG 


Vv 


图 15.6 应 用 ThinkPHP 中 的 扩展 类 上 传 文件 
实现 过 程 
具体 步骤 如 下 : | 
(1) 创建 006 项 目 根 目录 ， 在 根 目录 下 创建 项 目 文件 夹 App 和 Public 文件 夹 存储 CSS、 | 
图 片 和 JS 脚本 等 文件 。 | 
(2) 在 006 项 目 根 目录 下 ， 创 建 index.php 入 口 文件 。 其 关键 代码 如 下 : 


<?php 

define(CTHINK PATH''/ThinkPHP): /定义 ThinkPHP 框架 路 径 〈 相 对 于 入 口 文件 ) 
define(APP NAME', 'App): /定义 项 目 名 称 

define('APP PATH', '/App)): /定义 项 目 路 径 
require(THINK_PATH."/ThinkPHPphp"); /加载 框 架 入 口 文件 

App::run0: /实例 化 一 个 网 站 应 用 实例 


?> 


(3) 在 下 浏览 器 中 运行 入 口 文件 ， 自 动 生成 项 目 目录 。 
(4) 定位 到 App\Conf 目录 下 , 创建 config php 文件 , 通过 PDO 连接 MySQL 数据 库 。 
其 代码 如 下 : 


<?php 
Tetum array( 
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'DB_TYPE'=> pdo', 
| / 注意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 
| DB _DSN'=> 'mysql:host=localhost:dbname=db_databasel15', 
| 'DB_USER'=>'root, 
| DB PWD=>"111', 
| 'DB_PREFIX=>think ， 


| // 其 他 项 目 配 置 参数 …… 
'APP DEBUG' => false, // 关 闭 调试 模式 


由 
> 
(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 , 定义 index0 方 法 , 在 此 方法 中 没有 任何 其 他 操作 , 直接 指定 模板 页 index.html， 
在 模板 页 中 创建 表单 ， 添 加 文件 域 ， 将 图 片 提交 到 upload() 方 法 中 进行 处 理 。index() 方 法 
的 代码 如 下 : 


public function indexO{ 
S$this->display('index’"): 
h 
在 Index 控制 器 的 Index 模块 中 ， 定 义 upload( 方 法 ， 实 现 文件 上 传 的 功能 。 首 先 ， 载 
入 上 传 文件 类 ， 实 例 化 上 传 文件 类 ; 然后 ， 对 上 传 文件 的 大 小 、 类 型 、 存 储 路 径 进行 设置 ; 


接着 ， 调 用 上 传 文件 类 中 的 upload() 方 法 执行 文件 的 上 传 操作 ， 如 果 上 传 成 功 ， 则 将 上 传 
文件 的 信息 存储 到 指定 的 数据 表 中 ， 并 且 在 success.html 模板 文件 中 输出 上 传 图 片 ， 否 则 
输出 上 传 失败 的 错误 信息 ， 并 且 跳 转 到 index.html 页 。 其 完整 代码 如 下 : 


public function uploadO{ 
import("ORG Net.UploadFile"): // 载 入 上 传 文件 类 
Supload = new UploadFile0; // 实 例 化 上 传 类 
S$upload->maxSize =3145728:; /设置 附件 上 传 大 小 
S$upload->allowExts ”=array(jpg', 'gif, 'png', ipeg); 。 // 设 置 附件 上 传 类 型 
S$upload->savePath = './Public/Uploads/'; /设置 附件 上 传 目 录 
这 $upload->uploadO) { /上 传 成 功 
$info = S$upload->getUploadFileInfo(); 
Supfile = M("files"); // 实 例 化 User 对 象 
Supfile->create(); // 创 建 数据 对 象 
Supfile->tb_name = $info[0]["savename"]; // 保 存 上 传 图 片 名 称 
| Supfile->tb_path = $info[0]["savepath"]: // 保 存 上 传 图 片 路 径 
| Supfile->tb_date = date("Y-m-d H:i:s"); // 保 存 上 传 图 片 时 间 
| S$upfile->addO: // 写 入 用 户 数据 到 数据 库 
| $db = M('files’); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| $select = $db->order('id desc)->selectO: // 执 行 查询 语句 
| Sthis->assign('select', $select): // 模 板 变量 赋值 
| $this->success(" 文 件 上 传 成 功 ! 7; /上 传 成 功 
| }else{ 
| $info=$upload->getErrorMsg0: /上 传 失败 返回 错误 信息 
| S$this->redirect(index',", 5,$info); // 页 面 重 定向 
| } 
| } 
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'DB_TYPE'=> pdo', 
| / 注意 DSN 的 配置 针对 不 同 的 数据 库 有 所 区 别 
| DB _DSN'=> 'mysql:host=localhost:dbname=db_databasel15', 
| 'DB_USER'=>'root, 
| DB PWD=>"111', 
| 'DB_PREFIX=>think ， 


| // 其 他 项 目 配 置 参数 …… 
'APP DEBUG' => false, // 关 闭 调试 模式 


由 
> 
(5) 定位 到 \App\Lib\Action\ 目 录 下 ， 编 写 项 目 控制 器 。 创 建 mdex 模块 ， 继 承 系统 的 
Action 基础 类 , 定义 index0 方 法 , 在 此 方法 中 没有 任何 其 他 操作 , 直接 指定 模板 页 index.html， 
在 模板 页 中 创建 表单 ， 添 加 文件 域 ， 将 图 片 提交 到 upload() 方 法 中 进行 处 理 。index() 方 法 
的 代码 如 下 : 


public function indexO{ 
S$this->display('index’"): 
h 
在 Index 控制 器 的 Index 模块 中 ， 定 义 upload( 方 法 ， 实 现 文件 上 传 的 功能 。 首 先 ， 载 
入 上 传 文件 类 ， 实 例 化 上 传 文件 类 ; 然后 ， 对 上 传 文件 的 大 小 、 类 型 、 存 储 路 径 进行 设置 ; 


接着 ， 调 用 上 传 文件 类 中 的 upload() 方 法 执行 文件 的 上 传 操作 ， 如 果 上 传 成 功 ， 则 将 上 传 
文件 的 信息 存储 到 指定 的 数据 表 中 ， 并 且 在 success.html 模板 文件 中 输出 上 传 图 片 ， 否 则 
输出 上 传 失败 的 错误 信息 ， 并 且 跳 转 到 index.html 页 。 其 完整 代码 如 下 : 


public function uploadO{ 
import("ORG Net.UploadFile"): // 载 入 上 传 文件 类 
Supload = new UploadFile0; // 实 例 化 上 传 类 
S$upload->maxSize =3145728:; /设置 附件 上 传 大 小 
S$upload->allowExts ”=array(jpg', 'gif, 'png', ipeg); 。 // 设 置 附件 上 传 类 型 
S$upload->savePath = './Public/Uploads/'; /设置 附件 上 传 目 录 
这 $upload->uploadO) { /上 传 成 功 
$info = S$upload->getUploadFileInfo(); 
Supfile = M("files"); // 实 例 化 User 对 象 
Supfile->create(); // 创 建 数据 对 象 
Supfile->tb_name = $info[0]["savename"]; // 保 存 上 传 图 片 名 称 
| Supfile->tb_path = $info[0]["savepath"]: // 保 存 上 传 图 片 路 径 
| Supfile->tb_date = date("Y-m-d H:i:s"); // 保 存 上 传 图 片 时 间 
| S$upfile->addO: // 写 入 用 户 数据 到 数据 库 
| $db = M('files’); // 实 例 化 模型 类 ， 参 数 数据 表 名 称 ， 不 包含 前 级 
| $select = $db->order('id desc)->selectO: // 执 行 查询 语句 
| Sthis->assign('select', $select): // 模 板 变量 赋值 
| $this->success(" 文 件 上 传 成 功 ! 7; /上 传 成 功 
| }else{ 
| $info=$upload->getErrorMsg0: /上 传 失败 返回 错误 信息 
| S$this->redirect(index',", 5,$info); // 页 面 重 定向 
| } 
| } 
] . 428 。 
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(6) 定位 到 App\Tpl\default 目录 下 ， 创 建 mdex 模块 文件 夹 。 编 辑 index 操作 的 模板 


文件 index.html， 载 入 CSS 样式 文 ; 创建 表单 ， 定 义 文件 域 ， 将 上 传 图 片 提交 到 upload() | 


方法 中 进行 处 理 。 其 关键 代码 如 下 : 
<link href=" ROOT_ /Public/Css/style.css" rel="stylesheet" type="text/css" /> 


<form action=" URL_ /upload" method="post" enctype="multipart/form-data" name="forml" id= | 


"forml"> 
<tr> 
<td colspan="3" bgcolor="#FFFFFF" class="title" align="center"> 
选择 文件 : 
<input name="tb_path" type="file" id="tb_path" size="15" /> 
<input type="submit" name="button" id="button" value=" 提 交 " /> 
</td> 
</tr> 
</form> 
(7) 定位 到 App\Tpl\default 目录 下 ,创建 Public 模块 文件 夹 。 编 辑 success 操作 的 模 
板 文 件 success.html。 通 过 foreach 标签 循环 输出 模板 变量 传递 的 数据 ， 包 括 上 传 图 片 的 名 
称 ， 以 及 上 传 图 片 在 服务 器 中 的 存储 位 置 ; 通过 img 标签 根据 模板 变量 传递 的 名 称 和 路 径 
输出 上 传 的 图 片 。 其 代码 如 下 : 
<foreach name="select" item="select" > 
<tr class="title"> 
<td bgcolor="#FFFFF"> 上 传 图 片 : {$select.tb_name}</td> 
</tr> 
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</foreach> 
技术 要 点 


本 实例 主要 应 用 文件 上 传 扩展 类 (Lib\ORG\Net\UploadFile.class.php) 中 的 方法 ， 实 现 
文件 上 传 的 功能 。 

在 UploadFile 类 中 ， 可 以 对 上 传 文件 的 属性 (参数 ) 进行 控制 ， 其 可 控 属 性 如 表 15.3 
所 示 。 


表 15.3 在 UploadFile 类 中 上 传 文件 的 可 控 属性 


属 性 描述 
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savePath a y 4 
常量 定义 的 路 径 

ei 上 传 文件 的 保存 规则 ,必须 是 一 个 无 需 任何 参数 的 函数 名 , 例如 , time、uniqid com_ 
create_guid 等 ， 但 必须 保证 生成 的 文件 名 是 唯一 的 ， 默 认 是 uniqid 

hashType 传 文件 的 哈 希 验证 方法 ， 默 认 是 md5 file 

autoCheck 是 否 自动 检测 附件 ， 默 认为 自动 检测 
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</tr> 
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EC 
tS 
续 表 

属 性 描述 
UploadReplace 存在 同名 文件 是 否 是 覆盖 
allowExts 允许 上 传 的 文件 后 绥 〈 留 空 为 不 限制 )》 ， 使 用 数组 设置 ， 默 认为 空 数组 
allowTypes 允许 上 传 的 文件 类 型 〈 留 空 为 不 限制 )》 ， 使 用 数组 设置 ， 默 认为 空 数组 
thumb 是 否 需要 对 图 片 文件 进行 缩 略图 处 理 ， 默 认为 false 
thumbMaxWidth 缩 略 图 的 最 大 宽度 ， 多 个 使 用 去 号 分 隔 


thumbMaxHeight 


缩 略图 的 最 大 高 度 ， 多 个 使 用 去 号 分 隔 


thumbPrefix 缩 略 图 的 文件 前 级 ， 默 认为 thumb 

thumbSuffix 缩 略 图 的 文件 后 级 ， 默 认为 守 

thumbPath 缩 略 图 的 保存 路 径 ， 留 空 的 话 取 文件 上 传 目录 本 身 
thumbFile 指定 缩 略 图 的 文件 名 


thumbRemoveOrigin | 指定 缩 略 图 的 文件 名 


| _thumbRemoveOrigin | 生成 缩 略图 后 是 否 删除 原 图 


autoSub 是 否 使 用 子 目录 保 在 上 传 文件 

subType 子 目 录 创 建 方式 ， 默 认为 hash， 可 以 设置 为 hash 或 者 date 
dateFormat 子 目 录 方 式 为 date 的 时 候 指 定 日 期 格式 

hashLevel 子 目录 保存 的 层次 ， 默 认为 一 层 


上 传 文件 的 属性 设置 完成 后 ， 应 用 upload0 方 法 完成 文件 上 传 操作 。 
上 传 成 功 后 ， 应 用 getUploadFileInfo() 方 法 获取 附件 信息 。 其 返回 值 是 

中 元 素 的 含义 如 下 : 

上 传 的 表单 名 称 。 

上 传 文件 的 保存 路 径 。 

上 传 文件 的 原始 名 称 。 

上 传 文件 的 保存 名 称 。 

上 传 文件 的 大 小 。 

上 传 文件 的 MIME 类 型 。 

extension: 上 传 文件 的 后 级 类 型 。 

hash: 上 传 文件 的 哈 希 验证 字符 串 。 

如 果 上 传 失败 ， 则 应 用 getErrorMsg() 方 法 获取 错误 提示 信息 。 


-个 数组 ， 数 组 


key: 
savepath: 
name: 
savename: 


size: 


回回 加 网 加 罗网 网 


| 指点 迷津 
| 在 创建 文件 上 传 的 表单 时 ， 在 Form 标签 中 必须 设置 enctype="multipart/form-data"， 否 
| 则 文件 不 能 上 传 。 
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PHP 的 字符 编码 


本 章 读者 可 以 学 到 如 下 实例 : 

WI 实例 259 设计 GB2312 编码 格式 的 网 页 

WI 实例 260 设计 GBK 编码 格式 的 网 页 

WI 实例 261 设计 UTF-8 编码 格式 的 网 页 

吕 ” ”实例 262 通过 iconvO 函 数 实现 编码 格式 的 转 
”实例 263 ”避免 截取 超 长 文本 时 出 现 乱 码 

WI 实例 264 对 输出 的 数据 进行 编码 格式 转换 

WI ”实例 265 论坛 中 控制 帖子 标题 输出 的 长 度 


需 
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本 章 读者 可 以 学 到 如 下 实例 : 
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吕 ” ”实例 262 通过 iconvO 函 数 实现 编码 格式 的 转 
”实例 263 ”避免 截取 超 长 文本 时 出 现 乱 码 
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实例 259 设计 GB2312 编码 格式 的 网 页 


( 实例 位 置 : 配套 资源 \SL\16W259 ) 


本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编 码 为 一 一 一 


| GB2312 编码 格式 ， 运 行 本 实例 ， 如 图 16.1 所 示 ， G Hn. 

| 在 页 面 中 打印 出 明日 企业 网 的 页 面 编码 的 提示 信 这 挟 一 个 323512 六 得 格式 内 页 面 

| 息 ， 从 运行 结果 可 以 看 出 该 页 面 所 使 用 的 编码 为 

| GB2312 编码 格式 。 

| 实现 过 程 图 16.1 打印 明日 企业 网 的 页 面 编码 


具体 步骤 如 下 : 
(1) 创建 index.php 页 面 ， 并 设置 页 面 文件 的 编码 为 GB2312， 其 具体 设置 方法 可 参 


| 见 下 面 “ 技 术 要 点 ”中 的 相关 讲解 ， 这 里 不 再 次 述 。 


(2) 在 index.php 文件 中 通过 HTML 语言 的 meta 标记 设置 网 页 编码 为 GB2312 格式 ， 


| 具体 实现 代码 如 下 : 


<IDOCTYPE html PUBLIC "-WW3CWDTD XHTML 1.0 Transitional//EN" "http://www.w3.0org/TR/ 


| xhtmll/DTDAxhtmll-transitionaldtd"> 


<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title> 设 计 GB2312 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=gb2312" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 
</head> 


<div style="width: 487px; text-align:center; height:221px; line-height:221px; font-size:16pXx; 


| color:blue; background:url(img/bg.jpg)"> 


这 是 一 个 GB2312 编码 格式 的 页 面 
</div> 
</body> 
</html> 


设计 GB2312 编码 格式 的 网 页 需要 对 页 面 进行 两 点 设置 ， 首 先 使 用 编辑 器 设置 页 面 文 


， 件 的 编码 为 GB2312 格式 ， 然 后 通过 HTML 语言 的 meta 标记 或 PHP 的 header0 函 数 设置 
| 页面 编码 为 GB2312。 


设置 页 面 文件 编码 可 以 使 用 UltraEdit、Edit Plus 和 Zend Studio 等 编辑 器 。 下 面 将 以 


Zend Studio 为 合 讲解 如 何 设置 页 面 编码 。 


打开 Zend Studio 后 ， 选 择 要 设置 编码 的 文件 ， 然 后 单 击 鼠 标 右键 ， 在 弹出 的 快捷 菜 


| 单 中 选择 “属性 ”命令 《 见 图 162)， 将 弹出 如 图 163 所 示 的 页 面 必 性 对 话 棋 . 
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设计 GB2312 编码 格式 的 网 页 需要 对 页 面 进行 两 点 设置 ， 首 先 使 用 编辑 器 设置 页 面 文 


， 件 的 编码 为 GB2312 格式 ， 然 后 通过 HTML 语言 的 meta 标记 或 PHP 的 header0 函 数 设置 
| 页面 编码 为 GB2312。 


设置 页 面 文件 编码 可 以 使 用 UltraEdit、Edit Plus 和 Zend Studio 等 编辑 器 。 下 面 将 以 


Zend Studio 为 合 讲解 如 何 设置 页 面 编码 。 


打开 Zend Studio 后 ， 选 择 要 设置 编码 的 文件 ， 然 后 单 击 鼠 标 右键 ， 在 弹出 的 快捷 菜 
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O Prooerties iorindenhn 天 

Femmeter Resource > 
Le ah。 fdaflsionlindexphp 

Iype: Fi (PHP Cortert Type) 

Vpcation: DiWpp5erviwwwWRN5IODIWndecphp 

Be: 608 byles 


图 16.2 选择 “属性 ”命令 图 16.3 页 面 属性 对 话 框 


在 页 面 属性 对 话 框 中 选择 文件 编码 模块 ， 在 该 模块 的 其 他 编码 的 下 拉 列 表 框 中 选择 GBK 
编码 ， 然 后 单 击 “ 应 用 ”按钮 ， 最 后 单 击 “ 确 定 ” 按 钮 即 可 完成 对 页 面 文 件 编码 的 设置 。 | 


在 文件 编码 下 拉 列 表 中 并 没有 GB2312 编码 ， 而 GBK 编码 包含 简体 中 文 编码 ， 所 以 | 

这 里 选择 GBK 编码 。 | 

完成 对 页 面 文件 的 编码 设置 后 ， 还 需要 使 用 meta 标记 设置 页 面 编码 ， 其 设置 方法 如 下 : 
<meta http-equiv="content-type" content="text/html: charset=gb2312" /> 


实例 260 ”设计 GBK 编码 格式 的 网 页 


( 实例 位 置 : 配套 资源 \SL\16\260 ) 


实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编 码 为 
GBK 格式 。 运 行 本 实例 ， 如 图 16.4 所 示 ， 在 页 面 


中 打印 出 咖啡 小 屋 程序 所 使 用 的 页 面 编码 。 er 
实现 过 程 | 


具体 步骤 如 下 : 


(1) 创建 index.php 文件 , 并 使 用 Zend Studio 

编辑 器 设置 页 面 编码 为 GBK 格式 。 图 16.4 打印 咖啡 小 屋 的 页 面 编码 
(2) 在 index.php 文件 中 使 用 meta 标记 设置 

网 页 编码 为 GBK 格式 ， 并 在 页 面 中 打印 当前 页 面 所 使 用 的 编码 ， 其 具体 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3. oR | 
xhtmll/DTD/xhtmll-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
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图 16.2 选择 “属性 ”命令 图 16.3 页 面 属性 对 话 框 


在 页 面 属性 对 话 框 中 选择 文件 编码 模块 ， 在 该 模块 的 其 他 编码 的 下 拉 列 表 框 中 选择 GBK 
编码 ， 然 后 单 击 “ 应 用 ”按钮 ， 最 后 单 击 “ 确 定 ” 按 钮 即 可 完成 对 页 面 文 件 编码 的 设置 。 | 


在 文件 编码 下 拉 列 表 中 并 没有 GB2312 编码 ， 而 GBK 编码 包含 简体 中 文 编码 ， 所 以 | 

这 里 选择 GBK 编码 。 | 

完成 对 页 面 文件 的 编码 设置 后 ， 还 需要 使 用 meta 标记 设置 页 面 编码 ， 其 设置 方法 如 下 : 
<meta http-equiv="content-type" content="text/html: charset=gb2312" /> 


实例 260 ”设计 GBK 编码 格式 的 网 页 


( 实例 位 置 : 配套 资源 \SL\16\260 ) 


实例 说 明 
本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编 码 为 
GBK 格式 。 运 行 本 实例 ， 如 图 16.4 所 示 ， 在 页 面 


中 打印 出 咖啡 小 屋 程序 所 使 用 的 页 面 编码 。 er 
实现 过 程 | 


具体 步骤 如 下 : 


(1) 创建 index.php 文件 , 并 使 用 Zend Studio 

编辑 器 设置 页 面 编码 为 GBK 格式 。 图 16.4 打印 咖啡 小 屋 的 页 面 编码 
(2) 在 index.php 文件 中 使 用 meta 标记 设置 

网 页 编码 为 GBK 格式 ， 并 在 页 面 中 打印 当前 页 面 所 使 用 的 编码 ， 其 具体 代码 如 下 : 


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3. oR | 
xhtmll/DTD/xhtmll-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
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<head> 
<title> 设 计 GB2312 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=gbk" /> 
<link hre 人 ="css/style.css" rel="stylesheet" type="text/css" /> 


好 | 


<body> 
Nee | 
和 te <div style="width: 498px; text-align:center; height:332px; line-height:221px; font-size:16px; 


| color#FF3300; background:url(img/bg jpg)"> 
| 这 是 一 个 GBK 编码 格式 的 页 面 
</div> 
</body> 
</html> 


技术 要 点 


| 本 实例 的 关键 技术 是 设置 网 页 的 页 面 编码 为 GBK 格式 ， 同 样 其 设置 方法 也 包括 两 个 
| 部 分 。 首 先 设置 网 页 文件 的 编码 为 GBK 格式 ， 其 设置 方法 与 上 例 相同 ， 这 里 不 再 次 述 ， 
| 然后 使 用 HTML 语言 的 meta 标记 设置 网 页 的 编码 为 GBK。 其 设 定 代码 如 下 : 

| <meta http-equiv="content-type" content="text/html; charset=gbk" /> 


实例 261 设计 UTF-8 编码 格式 的 网 页 


( 实例 位 置 : 配套 资源 \SL\16W261 ) 


实例 说 明 


| 本 实例 主要 讲解 如 何 设置 网 页 的 页 面 编码 为 UTF-8 格式 。 运 行 本 实例 ， 如 图 16.5 所 
| 示 ， 将 在 页 面 中 打印 出 企业 邮局 收发 系统 所 使 用 的 页 面 编码 。 


ES 


A 当面 区 于 > 二 于 闻 件 改 活 >) 答 件 


这 是 一 个 UTF-2 澳 码 属 式 的 页 面 


| 图 165 打印 企业 邮局 收发 系统 的 页 面 编码 
| 实现 过 程 
| 具体 步骤 如 下 : 
(1) 创建 index.php 文件 ， 并 使 用 Zend Studio 编辑 器 设置 页 面 编码 为 UTF-8 格式 。 
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(2) 在 HTML 语言 的 meta 标记 中 设 定 当 前 页 面 所 使 用 的 编码 为 UTF-8 格式 ， 其 具 | | 
体 代码 如 下 : | 


<!DOCTYPE html PUBLIC "-WW3CWDTD XHTML 1.0 Transitional//EN" "http://www.w3. | 
xhtmll/DTD/xhtmll-transitional.dtd"> 
<html xmlns="http://www.w3.org/1999/xhtml"> 
<head> 
<title> 设 计 UTF-8 编码 格式 的 网 页 </title> 
<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 
<link href="css/style.css" rel="stylesheet" type="text/css" /> 
</head> 
<body> 
<br> | 
<div style="width: 978px; text-align:center; height:591px; line-height:591px; font-size:16px; | 
color:#09600C; background:url(img/bg.jpg)"> | 
这 是 一 个 UTF-8 编码 格式 的 页 面 
</div> 
</body> 
</html> 


技术 要 点 


UTF 是 国际 字符 集 转换 格式 Unicode/UCS Transformation Format) 的 缩写 ， 是 FCS | 
的 实际 表达 式 ， 按 其 基本 长 度 所 用 位 数 分 为 UTF-8/16/32 这 3 种 形式 ， 其 中 UTF-8 保持 字 | 
符 数字 一 个 字 节 ， 其 他 的 用 不 定 长 编码 到 最 多 6 个 字 节 ， 支 持 到 31 位 编码 。UTF 中 最 常 | 
用 的 就 是 UTF-8 编码 格式 ，UTF-8 使 用 8 位 字 节 编码 ， 通 常 使 用 1 一 3 位 字 节 来 表示 一 个 | 
字符 ， 字 符 的 编码 长 度 为 变 长 。 | 
UTF-8 字符 集 不 仅 包括 欧美 字符 ， 也 包括 中 国 、 日 本 和 韩国 的 全 角 字符 。 因 此 ， 在 网 | 
页 中 使 用 UTF-8 字符 集 可 以 使 用 户 在 不 安装 中 文 编码 的 情况 下 浏览 到 大 部 分 中 文字 符 。 | 
本 实例 设置 页 面 为 UTF-8 编码 ， 首 先 需要 使 用 编辑 工具 设置 页 面 文件 编码 为 UTF-8 | 
编码 ， 然 后 使 用 HTML 的 meta 标记 设置 网 页 编码 为 UTF-8 编码 ， 其 设置 方法 如 下 : | 
<meta http-equiv="content-type" content="text/html; charset=utf-8" /> 


实例 262 通过 iconv0 函 数 实 现 编码 格式 的 转换 


( 实例 位 置 配套 资源 \SL\16\262 视频 位 置 : 配套 资源 \SP\16\262 ) 


实例 说 明 
在 Dreamweaver 开 发 工具 中 , 创建 一 个 UTF-8 编码 格式 的 网 页 ,应 用 PHP 中 的 setlocale0 | 
函数 完成 区 域 化 设置 ， 输 出 美式 的 系统 当前 时 间 和 中 文 的 系统 当前 时 间 。 在 输出 中 文 的 系 | 
统 当前 时 间 时 ， 因 为 strftimeO 函 数 的 返回 值 为 GB2312 编码 ， 而 当前 页 面 使 用 的 是 UTF-8 | 
编码 格式 ， 所 以 直接 输出 将 会 出 现 乱 码 ， 如 图 16.6 所 示 。 所 以 必须 应 用 编码 格式 转换 函数 | 
对 它 的 返回 值 进行 编码 格式 转换 才能 够 正常 输出 中 文 格式 的 时 间 , 这 里 应 用 iconvO 函 数 对 | 
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strftime() 函 数 的 返回 值 进行 编码 格式 转换 ， 转 换 后 的 运行 结果 如 图 16.7 所 示 。 


地 址 中 | 丑 


lc6.1 5s/arf20/mhyol/ 研 ] 区 苇 到 幅 痊 刀 


Wedresday November 2010 习 er2010 


| 
| 

食 扩 | 100 Dn 2010 

A | EE FO Os i a 
| 


图 16.6 输出 中 文 时 间 乱 码 图 16.7 正常 输出 中 文 时 间 


本 实例 的 代码 如 下 : 
<2php 
header("Content-Type:text/html;charset=utf-8"); 
setlocale(LC_ALL, 'en_ US"); // 设 置 为 美式 英语 
echo strfime("%A %e %B %Y", timeO); /输出 当前 时 间 
echo "<br>"; 
setlocale(LC_ALL, 'chs"): /设置 为 中 文 
$dates=strftime("%A %e %B %Y", time0): /输出 当前 时 间 
echo iconv("gb2312","utf-8",$dates): /输出 经 过 编码 格式 转换 后 的 中 文 时 间 


| 全 

| 技术 要 点 

| 木 实例 应 用 iconv0 函 数 转换 编码 格式 ， 其 语法 格式 如 下 
string iconv ( string in_charset, string out_charset, string str ) 


| 参数 in_charset 为 转换 输入 字符 串 类 型 ， 参 数 out_charset 为 输出 字符 串 类 型 ， 参 数 str 
| 为 要 转换 编码 风格 的 字符 串 集 。 


实例 263 避免 截取 超 长 文本 时 出 现 乱 码 


( 实例 位 置 配套 资源 \SL\16\263 ”视频 位 置 : 配套 资源 \SP\16\263 ) 


说 昌 

| substr0 函 数 是 按 字 节 进行 截取 字符 串 Os a 
| 的 ， 在 截取 中 文字 符 串 时 ， 由 于 一 个 汉字 是 | 
| 由 两 个 字符 组 成 的 ， 所 以 如 果 只 截取 1 个 字 《的 于 开业 | 
| 符 就 会 出 现 乱码 。 本 实例 使 用 自 定义 函数 Eee 
| msubstr0 来 解决 对 中 文字 符 串 进行 截取 时 出 ee aa 
| 现 乱码 的 问题 ， 运 行 结果 如 图 16.8 所 示 。 图 16.8 ”使 用 msubstr0 函 数 解决 中 文 
实现 过 程 字符 串 截取 时 的 乱码 


| 创建 mdex.php 文件 ， 定 义 msubstr0 函 数 ， 对 中 文字 符 串 进行 截取 。 创 建 form 表单 ， 
| 提交 字符 串 截 取 的 开始 位 置 和 长 度 ， 然 后 调用 msubstr0 函 数 对 字符 串 进行 截取 ， 并 输出 截 
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取 结果 。 代 码 如 下 : 


<?php 
function msubstr($str, $start, $len) { //$str 指 的 是 字符 串 ，$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 
的 是 长 度 
$strlen = $start + $len; // 用 $strlen 存储 字符 串 的 总 长 度 〈 从 字符 串 的 起 始 位 置 到 字符 串 的 总 长 度 
for($i=0; $i< $strlen; $i++) { /通过 for 循环 语句 ， 循 环 读 取 字 符 串 
下 (ord (substr ( $str, $i, 1 ) ) > 0xa0) { /如 果 字 符 串 中 首 个 字 节 的 ASCI 序 数值 大 于 0xa0， 
则 表示 为 汉字 
$tmpstr = substr ( $str, $i, 2 ); /每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 


$i++; /变量 自 加 1 
j} else { /如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
$tmpstr .= substr ( $str, $i, 1 ); 
} 
> 
Teturn $tmpstr; // 输 出 字符 串 
y 


$string=" 吉 林 省 明日 科技 有 限 公司 是 一 家 以 计算 机 软件 技术 为 核心 的 高 科技 型 企业 "; 
$str=msubstr($string,$_ POST[te].$_POST[tx]): 

echo $str; 

?> 


技术 要 点 


对 中 文字 符 串 的 截取 虽说 是 通过 自 定义 函数 来 完成 的 ， 但 是 其 根本 还 是 应 用 substr 函 
数 ， 只 是 在 进行 字符 串 截取 时 ， 对 字符 串 的 类 型 进行 了 判断 。 
对 截取 字符 串 中 首 个 字 节 的 ASCII 序数 值 进行 判断 ， 如 果 ASCII 序数 值 大 于 0xa0， 
则 表示 为 汉字 ， 那么 在 应 用 substr0 函 数 进行 截取 时 ,就 以 两 个 字 节 为 单位 进行 稚 取 ; 如 果 
ASCII 序数 值 小 于 0xa0， 则 表示 为 英文 字符 串 ， 那么 在 应 用 substr0 函 数 进行 截取 时 ,就 以 
1 个 字 节 为 单位 进行 截取 。 这 样 将 中 文字 符 串 和 英文 字符 串 分 隔 进行 截取 就 避免 了 出 现 乱 
码 的 问题 。 
自 定义 函数 msubstr0 的 语法 如 下 : 
function msubstr($str, $start, $len) { //$str 指 的 是 字符 串 ，S$start 指 的 是 字符 串 的 起 始 位 置 ，$len 指 
的 是 长 度 
$strlen = $start + $len; // 用 $strlen 存储 字符 串 的 总 长 度 〔 从 字符 串 的 起 始 位置 到 字符 串 的 总 长 度 ) 
for($i= 0; $i < $strlen; $i++) { // 通 过 for 循环 语句 ， 循 环 读 取 字符 串 
让 (ord ( substr ( $str, $i, 1 ) ) > 0xa0) ”// 如 果 字 符 串 中 首 个 字 节 的 ASCI 序 数值 大 于 0xa0， 
则 表示 为 汉字 
$tmpstr .= substr ( $str, $i, 2 );// 每 次 取出 两 位 字符 赋 给 变量 $tmpstr， 即 等 于 一 个 汉字 
$i++; /变量 自 加 1 
} else{ /如 果 不 是 汉字 ， 则 每 次 取出 一 位 字符 赋 给 变量 $tmpstr 
Stmpstr = substr ( $str, $i, 1 ): 
} 
} 
return $tmpstr; /| 输出 字符 串 
} 


参数 $str 是 指定 被 截取 的 字符 串 ; 参数 $strart 是 截取 的 开始 位 置 ， 参 数 $len 是 截取 的 
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| 长度。 返回 值 stmpstr 是 截取 后 的 字符 串 。 


实例 264 ”对 输出 的 数据 进行 编码 格式 转换 
鲜 | ( 实例 位 置 配套 资源 \SL\16W264 视频 位 置 配套 资源 \SP\16\264 ) 


实例 说 


| PHP 不 仅 可 以 与 MySQL 数据 库 搭配 使 用 ， 也 可 以 与 其 他 数据 库 进 行 联合 应 用 。 在 本 
| 实例 中 ， 通 过 PHP 操作 Access 数据 库 ， 完 成 数据 库 中 数据 的 循环 输出 ， 并 且 通 过 iconv0 
| 函数 对 输出 数据 的 编码 格式 进行 转换 ， 运 行 效果 如 图 16.9 所 示 。 


《PHP 从 入 门 到 精通 》 
《PHP 项 目 开发 全 程 实录 》 清华 大 学 出 版 社 
《PHP 开 发 实战 宝典 》 清华 大 学 出 版 社 


| 图 16.9 循环 输出 数据 库 中 的 数据 

| 实现 过 程 

| 具体 步骤 如 下 ; 

(1) 建立 数据 库 连 接 文件 conn.php 实现 与 Access 数据 库 的 连接 ， 代 码 如 下 : 

<2php 
$conn = new com("adodb.connection"): // 实 例 化 com 类 
$connstr="driver={microsoft access driver (*.mdb)}; dbq=". realpath("data/db_database16.mdb"); 
// 连 接 db_database16 数据 库 
$conn->open($connstr); // 返 回 连接 对 象 
2 


| (2) 创建 index.php 文件 ， 包 含 数据 库 连 接 文 件 ， 调 用 ADO 中 的 方法 操作 Access 数 
| 据 库 中 的 数据 ， 并 通过 while 语句 循环 输出 数据 库 中 的 数据 。 其 关键 代码 如 下 : 


<?php 
$sql="select * from tb_book"; // 定 义 SQL 语句 
S$rs=new com("adodb.recordset"): /实例 化 ADO 中 的 方法 
S$rs->open($sql,$conn,1,3); // 执 行 SQL 语句 
while(!S$rs->eof){ // 循 环 输出 查询 结果 
> 
<tr> 


| <td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk','"utf-8', 
| Srs->fields('bookname')->value):?></div></td> 
| <td height="25" bgcolor="#FFFFFF"><div align="center"><?php echo iconv('gbk',"utf-8', 
| Sgrs->fields('pub')->value):?></div></td> 
| </t> 

<2php 
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指点 迷津 

本 实例 中 的 文件 都 采用 的 是 UTF-8 编 码 格式 ,但 是 通过 ADO 中 的 方法 读 取 到 的 Access ， 
数据 库 中 的 数据 采用 的 是 GBK 的 编码 ， 所 以 在 页 面 中 直接 输出 时 将 出 现 乱码 ， 所 以 必须 | 
通过 iconv0O 函 数 对 输出 的 数据 进行 编码 格式 的 转换 才能 保证 数据 的 正常 输出 。 | 


技术 要 点 


在 本 实例 中 , PHP 通过 预先 定义 类 com 调用 ADO 方法 操纵 Access 数据 库 。com 类 详 | 
细 说 明 如 下 ; 


string com::com( string module_ name [, string server_name [, int codepage]]) 


参数 说 明 : 
回 module name: 被 请 求 组 件 的 名 字 或 class-id。 
回 server_ name: DCOM 服务 器 的 名 字 。 | 
回 “codepage: 指定 用 于 将 PHP 字符 串 转 换 成 UNICODE 字符 串 的 代码 页 ， 反 之 亦 | 
然 。 该 参数 的 取 值 有 CP_ACP、CP MACCP、CP OEMCP、CP SYMBOL 、 | 
CP_ THREAD ACP、CP UTF7 和 CP_UTF8。 
实例 265 论坛 中 控制 帖子 标题 输出 的 长 度 
( 实例 位 置 : 配套 资源 \SL\16\265 视频 位 置 配套 资源 \SP\16\265 ) 
实例 说 明 


在 论坛 中 输出 帖子 的 标题 时 ， 为 了 确保 页 面 的 美观 及 完整 性 ， 必 须 控制 超 长 标题 的 输 | 
出 , 并 以 省 略 号 来 替换 , 此 时 就 需要 对 帖子 的 标题 进行 截取 , 这 里 推荐 读者 使 用 mb_substr0 | 
函数 对 帖子 的 标题 进行 截取 ， 这 样 可 以 避免 截取 中 文 时 出 现 乱码 的 问题 。 在 本 实例 中 完成 | 
论坛 中 帖子 标题 的 循环 输出 ， 并 且 对 超 长 的 标题 进行 截取 ， 同 时 使 用 省 略 号 进行 替换 ， 运 | 
行 效果 如 图 16.10 所 示 。 | 
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指点 迷津 

本 实例 中 的 文件 都 采用 的 是 UTF-8 编 码 格式 ,但 是 通过 ADO 中 的 方法 读 取 到 的 Access ， 
数据 库 中 的 数据 采用 的 是 GBK 的 编码 ， 所 以 在 页 面 中 直接 输出 时 将 出 现 乱码 ， 所 以 必须 | 
通过 iconv0O 函 数 对 输出 的 数据 进行 编码 格式 的 转换 才能 保证 数据 的 正常 输出 。 | 


技术 要 点 


在 本 实例 中 , PHP 通过 预先 定义 类 com 调用 ADO 方法 操纵 Access 数据 库 。com 类 详 | 
细 说 明 如 下 ; 


string com::com( string module_ name [, string server_name [, int codepage]]) 


参数 说 明 : 
回 module name: 被 请 求 组 件 的 名 字 或 class-id。 
回 server_ name: DCOM 服务 器 的 名 字 。 | 
回 “codepage: 指定 用 于 将 PHP 字符 串 转 换 成 UNICODE 字符 串 的 代码 页 ， 反 之 亦 | 
然 。 该 参数 的 取 值 有 CP_ACP、CP MACCP、CP OEMCP、CP SYMBOL 、 | 
CP_ THREAD ACP、CP UTF7 和 CP_UTF8。 
实例 265 论坛 中 控制 帖子 标题 输出 的 长 度 
( 实例 位 置 : 配套 资源 \SL\16\265 视频 位 置 配套 资源 \SP\16\265 ) 
实例 说 明 


在 论坛 中 输出 帖子 的 标题 时 ， 为 了 确保 页 面 的 美观 及 完整 性 ， 必 须 控制 超 长 标题 的 输 | 
出 , 并 以 省 略 号 来 替换 , 此 时 就 需要 对 帖子 的 标题 进行 截取 , 这 里 推荐 读者 使 用 mb_substr0 | 
函数 对 帖子 的 标题 进行 截取 ， 这 样 可 以 避免 截取 中 文 时 出 现 乱码 的 问题 。 在 本 实例 中 完成 | 
论坛 中 帖子 标题 的 循环 输出 ， 并 且 对 超 长 的 标题 进行 截取 ， 同 时 使 用 省 略 号 进行 替换 ， 运 | 
行 效果 如 图 16.10 所 示 。 | 
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”实现 过 程 


具体 步骤 如 下 : 
(1) 编写 数据 库 连 接 文 件 conn.php， 同 时 设置 数据 库 的 编码 格式 为 UTF-8。 
| (2) 创建 mdexphp 文件 ， 通 过 include0 语 句 包含 数据 库 的 连接 文件 ， 完 成 数据 库 中 
数据 的 循环 输出 。 通 过 mb_strlen0 函 数 统计 帖子 标题 的 长 度 ， 通 过 站 语句 判断 如 果 帖 子 标 
， 题 长 度 超过 5 个 字 节 ， 那 么 通过 mb_substr0 函 数 对 帖子 标题 进行 截取 ， 并 且 通 过 省 略 号 蔡 
| 换 被 截取 的 内 容 ， 否 则 正常 输出 帖子 的 标题 。 其 关键 代码 如 下 : 


<2php 
include_once("conn/conn.php"); // 载 入 数据 库 连 接 文件 
$query=mysql_query("select * from tb_guestbook",$conn); // 执 行 查询 语句 
while($myrow=mysql fetch array($query)){ // 循 环 输出 查询 结果 
?> 
<tr> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow["id']:?></td> 
<td align="center" bgcolor="#FFFFFF"> 
<?php 
$str=mb_strlen($myrow[title],"UTF-8"): /获取 帖子 标题 的 长 度 
if($str>5){ 1/ 判断 如 果 长 度 超出 5 个 字 节 
$title=mb_substr($myrow['title"],0,5,"UTF-8"); /对 帖子 的 标题 进行 截取 
echo Stitle."..."; /| 输出 帖子 标题 
Jelse{ 
echo $myrow['title']; // 输 出 帖子 标题 
} 
?> 
</td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow['createtime']:?></td> 
</t> 
| <2php }2> 
| 技术 要 点 


| 本 实例 应 用 mb_substr 0 函数 对 字符 串 进行 截取 操作 , 其 作用 是 将 指定 字符 串 以 特定 编 
| 码 格式 从 指定 位 置 开始 ， 向 后 截取 指定 长 度 的 字 节 。 其 语法 结构 如 下 : 

| string mb_substr ( string str int start [, int length [, string encoding]] ) 

| 该 函数 与 substr0 函 数 的 功能 类 似 。 参 数 str 为 指定 被 截取 的 字符 串 ， 参数 start 为 截取 
| 从 该 字符 串 的 起 始 位 置 ， 参 数 length 为 指定 截取 长 度 ， 参 数 encoding 为 指定 的 编码 格式 。 

| 其 中 本 实例 的 encoding 参数 为 UTF-8, 另外 也 可 以 根据 实际 情况 设置 该 参数 为 GB2312 等 。 
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| 换 被 截取 的 内 容 ， 否 则 正常 输出 帖子 的 标题 。 其 关键 代码 如 下 : 


<2php 
include_once("conn/conn.php"); // 载 入 数据 库 连 接 文件 
$query=mysql_query("select * from tb_guestbook",$conn); // 执 行 查询 语句 
while($myrow=mysql fetch array($query)){ // 循 环 输出 查询 结果 
?> 
<tr> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow["id']:?></td> 
<td align="center" bgcolor="#FFFFFF"> 
<?php 
$str=mb_strlen($myrow[title],"UTF-8"): /获取 帖子 标题 的 长 度 
if($str>5){ 1/ 判断 如 果 长 度 超出 5 个 字 节 
$title=mb_substr($myrow['title"],0,5,"UTF-8"); /对 帖子 的 标题 进行 截取 
echo Stitle."..."; /| 输出 帖子 标题 
Jelse{ 
echo $myrow['title']; // 输 出 帖子 标题 
} 
?> 
</td> 
<td align="center" bgcolor="#FFFFFF"><?php echo $myrow['createtime']:?></td> 
</t> 
| <2php }2> 
| 技术 要 点 


| 本 实例 应 用 mb_substr 0 函数 对 字符 串 进行 截取 操作 , 其 作用 是 将 指定 字符 串 以 特定 编 
| 码 格式 从 指定 位 置 开始 ， 向 后 截取 指定 长 度 的 字 节 。 其 语法 结构 如 下 : 

| string mb_substr ( string str int start [, int length [, string encoding]] ) 

| 该 函数 与 substr0 函 数 的 功能 类 似 。 参 数 str 为 指定 被 截取 的 字符 串 ， 参数 start 为 截取 
| 从 该 字符 串 的 起 始 位 置 ， 参 数 length 为 指定 截取 长 度 ， 参 数 encoding 为 指定 的 编码 格式 。 

| 其 中 本 实例 的 encoding 参数 为 UTF-8, 另外 也 可 以 根据 实际 情况 设置 该 参数 为 GB2312 等 。 
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